-- Hoogle documentation, generated by Haddock
-- See Hoogle, http://www.haskell.org/hoogle/


-- | A dependently typed functional programming language and proof assistant
--   
--   Agda is a dependently typed functional programming language: It has
--   inductive families, which are similar to Haskell's GADTs, but they can
--   be indexed by values and not just types. It also has parameterised
--   modules, mixfix operators, Unicode characters, and an interactive
--   Emacs interface (the type checker can assist in the development of
--   your code).
--   
--   Agda is also a proof assistant: It is an interactive system for
--   writing and checking proofs. Agda is based on intuitionistic type
--   theory, a foundational system for constructive mathematics developed
--   by the Swedish logician Per Martin-Löf. It has many similarities with
--   other proof assistants based on dependent types, such as Coq, Idris,
--   Lean and NuPRL.
--   
--   This package includes both a command-line program (agda) and an Emacs
--   mode. If you want to use the Emacs mode you can set it up by running
--   <tt>agda-mode setup</tt> (see the README).
--   
--   Note that the Agda package does not follow the package versioning
--   policy, because it is not intended to be used by third-party packages.
@package Agda
@version 2.7.0

module Agda.Interaction.ExitCode
data AgdaError

-- | 1
UnknownError :: AgdaError

-- | 42
TCMError :: AgdaError

-- | 71
OptionError :: AgdaError

-- | 113
CommandError :: AgdaError

-- | 154
ImpossibleError :: AgdaError

-- | Return the error corresponding to an exit code from the Agda process
agdaErrorToInt :: AgdaError -> Int
agdaErrorFromInt :: Int -> Maybe AgdaError

-- | The computation <a>exitSuccess</a> is equivalent to <a>exitWith</a>
--   <a>ExitSuccess</a>, It terminates the program successfully.
exitSuccess :: IO a
exitAgdaWith :: AgdaError -> IO a
instance GHC.Enum.Bounded Agda.Interaction.ExitCode.AgdaError
instance GHC.Enum.Enum Agda.Interaction.ExitCode.AgdaError
instance GHC.Classes.Eq Agda.Interaction.ExitCode.AgdaError
instance GHC.Show.Show Agda.Interaction.ExitCode.AgdaError


-- | Defines <a>CutOff</a> type which is used in
--   <a>Agda.Interaction.Options</a>. This module's purpose is to eliminate
--   the dependency of <a>Agda.TypeChecking.Monad.Base</a> on the
--   termination checker and everything it imports.
module Agda.Termination.CutOff

-- | Cut off structural order comparison at some depth in termination
--   checker?
data CutOff

-- | <tt>c &gt;= 0</tt> means: record decrease up to including
--   <tt>c+1</tt>.
CutOff :: !Int -> CutOff
DontCutOff :: CutOff

-- | The default termination depth.
defaultCutOff :: CutOff
instance GHC.Classes.Ord Agda.Termination.CutOff.CutOff
instance GHC.Classes.Eq Agda.Termination.CutOff.CutOff
instance GHC.Show.Show Agda.Termination.CutOff.CutOff
instance Control.DeepSeq.NFData Agda.Termination.CutOff.CutOff


-- | Semirings.
module Agda.Termination.Semiring

-- | <tt>HasZero</tt> is needed for sparse matrices, to tell which is the
--   element that does not have to be stored. It is a cut-down version of
--   <tt>SemiRing</tt> which is definable without the implicit
--   <tt>?cutoff</tt>.
class Eq a => HasZero a
zeroElement :: HasZero a => a

-- | Semirings.
data Semiring a
Semiring :: (a -> a -> a) -> (a -> a -> a) -> a -> Semiring a

-- | Addition.
[add] :: Semiring a -> a -> a -> a

-- | Multiplication.
[mul] :: Semiring a -> a -> a -> a

-- | Zero. The one is never used in matrix multiplication , one :: a -- ^
--   One.
[zero] :: Semiring a -> a
integerSemiring :: Semiring Integer
intSemiring :: Semiring Int

-- | The standard semiring on <a>Bool</a>s.
boolSemiring :: Semiring Bool
instance Agda.Termination.Semiring.HasZero GHC.Num.Integer.Integer
instance Agda.Termination.Semiring.HasZero GHC.Types.Int


-- | Contexts with at most one hole.
module Agda.Utils.AffineHole
data AffineHole r a

-- | A constant term.
ZeroHoles :: a -> AffineHole r a

-- | A term with one hole and the (old) contents.
OneHole :: (r -> a) -> r -> AffineHole r a

-- | A term with many holes (error value).
ManyHoles :: AffineHole r a
instance GHC.Base.Functor (Agda.Utils.AffineHole.AffineHole r)
instance GHC.Base.Applicative (Agda.Utils.AffineHole.AffineHole r)

module Agda.Utils.Applicative

-- | Guard: return the action <tt>f</tt> only if the boolean is
--   <tt>True</tt>
(?*>) :: Alternative f => Bool -> f a -> f a

-- | Guard: return the value <tt>a</tt> only if the boolean is
--   <tt>True</tt>
(?$>) :: Alternative f => Bool -> a -> f a

-- | Branch over a <a>Foldable</a> collection of values.
foldA :: (Alternative f, Foldable t) => t a -> f a

-- | Branch over a <a>Foldable</a> collection of values using the supplied
--   action.
foldMapA :: (Alternative f, Foldable t) => (a -> f b) -> t a -> f b

-- | Better name for <a>for</a>.
forA :: (Traversable t, Applicative f) => t a -> (a -> f b) -> f (t b)


-- | Boolean algebras and types isomorphic to <a>Bool</a>.
--   
--   There are already solutions for <a>Boolean</a> algebras in the Haskell
--   ecosystem, but they do not offer easy instantiations for types
--   isomorphic to <a>Bool</a>. In particular, if type <tt>a</tt> is
--   isomorphic to <a>Bool</a>, so it satisfies `IsBool a`, we would like
--   to instantiate 'Boolean a' by just giving <a>true</a> and
--   <a>false</a>. To facilitate this within the limits of the Haskell
--   class system, we define the class <a>Boolean</a> mutually with class
--   <a>IsBool</a>, so that operations <a>not</a>, <a>(&amp;&amp;)</a>, and
--   <a>(||)</a> can get default implementations.
--   
--   Usage: <tt> import Prelude hiding ( not, (&amp;&amp;), (||) ) import
--   Agda.Utils.Boolean </tt>
module Agda.Utils.Boolean

-- | Boolean algebras.
class Boolean a
fromBool :: Boolean a => Bool -> a
true :: Boolean a => a
false :: Boolean a => a
not :: Boolean a => a -> a
(&&) :: Boolean a => a -> a -> a
(||) :: Boolean a => a -> a -> a
implies :: Boolean a => a -> a -> a

-- | Set difference, dual to <a>implies</a>.
butNot :: Boolean a => a -> a -> a
not :: (Boolean a, IsBool a) => a -> a
(&&) :: (Boolean a, IsBool a) => a -> a -> a
(||) :: (Boolean a, IsBool a) => a -> a -> a
infixr 3 &&
infixr 2 ||

-- | Types isomorphic to <a>Bool</a>.
class (Boolean a, Eq a) => IsBool a
toBool :: IsBool a => a -> Bool
ifThenElse :: IsBool a => a -> b -> b -> b
fromBool1 :: IsBool a => (Bool -> Bool) -> a -> a
fromBool2 :: IsBool a => (Bool -> Bool -> Bool) -> a -> a -> a
instance Agda.Utils.Boolean.Boolean GHC.Types.Bool
instance Agda.Utils.Boolean.IsBool GHC.Types.Bool
instance Agda.Utils.Boolean.Boolean b => Agda.Utils.Boolean.Boolean (a -> b)


-- | Kinds of standard universes: <tt>Prop</tt>, <tt>Type</tt>,
--   <tt>SSet</tt>.
module Agda.Syntax.Internal.Univ

-- | Flavor of standard universe (<tt>Prop &lt; Type &lt; SSet</tt>,).
data Univ

-- | Fibrant universe of propositions.
UProp :: Univ

-- | Fibrant universe.
UType :: Univ

-- | Non-fibrant universe.
USSet :: Univ

-- | We have <tt>IsFibrant &lt; IsStrict</tt>.
data IsFibrant

-- | Fibrant universe.
IsFibrant :: IsFibrant

-- | Non-fibrant universe.
IsStrict :: IsFibrant

-- | The successor universe type of a universe.
univUniv :: Univ -> Univ

-- | Compute the universe type of a function space from the universe types
--   of domain and codomain.
funUniv :: Univ -> Univ -> Univ

-- | Conclude <tt>u1</tt> from <tt>funUniv u1 u2</tt> and <tt>u2</tt>.
domainUniv :: Bool -> Univ -> Univ -> Maybe Univ

-- | Conclude <tt>u2</tt> from <tt>funUniv u1 u2</tt> and <tt>u1</tt>.
codomainUniv :: Univ -> Univ -> Maybe Univ

-- | Fibrancy of standard universes.
univFibrancy :: Univ -> IsFibrant

-- | Hacky showing of standard universes, does not take actual names into
--   account.
showUniv :: Univ -> String
instance Control.DeepSeq.NFData Agda.Syntax.Internal.Univ.Univ
instance GHC.Generics.Generic Agda.Syntax.Internal.Univ.Univ
instance GHC.Enum.Enum Agda.Syntax.Internal.Univ.Univ
instance GHC.Enum.Bounded Agda.Syntax.Internal.Univ.Univ
instance GHC.Show.Show Agda.Syntax.Internal.Univ.Univ
instance GHC.Classes.Ord Agda.Syntax.Internal.Univ.Univ
instance GHC.Classes.Eq Agda.Syntax.Internal.Univ.Univ
instance GHC.Generics.Generic Agda.Syntax.Internal.Univ.IsFibrant
instance GHC.Classes.Ord Agda.Syntax.Internal.Univ.IsFibrant
instance GHC.Classes.Eq Agda.Syntax.Internal.Univ.IsFibrant
instance GHC.Show.Show Agda.Syntax.Internal.Univ.IsFibrant
instance Agda.Utils.Boolean.Boolean Agda.Syntax.Internal.Univ.IsFibrant
instance Agda.Utils.Boolean.IsBool Agda.Syntax.Internal.Univ.IsFibrant


-- | Agda strings uses Data.Text [1], which can only represent unicode
--   scalar values [2], excluding the surrogate code points <a>3</a>. To
--   allow <tt>primStringFromList</tt> to be injective we make sure
--   character values also exclude surrogate code points, mapping them to
--   the replacement character <tt>U+FFFD</tt>.
--   
--   See #4999 for more information.
--   
--   <ul>
--   <li><i>1</i>
--   <a>https://hackage.haskell.org/package/text-1.2.4.0/docs/Data-Text.html#g:2</a></li>
--   <li><i>2</i>
--   <a>https://www.unicode.org/glossary/#unicode_scalar_value</a></li>
--   <li><i>3</i>
--   <a>https://www.unicode.org/glossary/#surrogate_code_point</a></li>
--   </ul>
module Agda.Utils.Char

-- | The unicode replacement character � .
replacementChar :: Char

-- | Is a character a surrogate code point.
isSurrogateCodePoint :: Char -> Bool

-- | Map surrogate code points to the unicode replacement character.
replaceSurrogateCodePoint :: Char -> Char

-- | Total function to convert an integer to a character. Maps surrogate
--   code points to the replacement character <tt>U+FFFD</tt>.
integerToChar :: Integer -> Char


-- | Expand environment variables in strings
module Agda.Utils.Environment

-- | List of environment variable bindings.
type EnvVars = [(String, String)]
expandEnvironmentVariables :: String -> IO String

-- | Expand a telescope of environment variables (each value may refer to
--   variables earlier in the list).
expandEnvVarTelescope :: String -> EnvVars -> EnvVars
instance GHC.Show.Show Agda.Utils.Environment.Token
instance GHC.Classes.Eq Agda.Utils.Environment.Token


-- | A pure MonadFail.
module Agda.Utils.Fail
newtype Fail a
Fail :: Either String a -> Fail a
[runFail] :: Fail a -> Either String a
runFail_ :: Fail a -> a
instance GHC.Base.Monad Agda.Utils.Fail.Fail
instance GHC.Base.Applicative Agda.Utils.Fail.Fail
instance GHC.Base.Functor Agda.Utils.Fail.Fail
instance Control.Monad.Fail.MonadFail Agda.Utils.Fail.Fail

module Agda.Utils.Function

-- | <tt><a>iterate'</a> n f x</tt> applies <tt>f</tt> to <tt>x</tt>
--   <tt>n</tt> times and returns the result.
--   
--   The applications are calculated strictly.
iterate' :: Integral i => i -> (a -> a) -> a -> a

-- | <tt>applyWhen b f a</tt> applies <tt>f</tt> to <tt>a</tt> when
--   <tt>b</tt>.
applyWhen :: IsBool b => b -> (a -> a) -> a -> a

-- | Monadic version of <a>iterateUntil</a>.
iterateUntilM :: Monad m => (a -> a -> Bool) -> (a -> m a) -> a -> m a

-- | Monadic version of <tt>applyWhen</tt>
applyWhenM :: (IsBool b, Monad m) => m b -> (m a -> m a) -> m a -> m a

-- | <tt>applyUnless b f a</tt> applies <tt>f</tt> to <tt>a</tt> unless
--   <tt>b</tt>.
applyUnless :: IsBool b => b -> (a -> a) -> a -> a

-- | Repeat a state transition <tt>f :: a -&gt; (b, a)</tt> with output
--   <tt>b</tt> while condition <tt>cond</tt> on the output is true. Return
--   all intermediate results and the final result where <tt>cond</tt> is
--   <tt>False</tt>.
--   
--   Postconditions (when it terminates): <tt>fst (last (iterWhile cond f
--   a)) == False</tt>. <tt>all fst (init (interWhile cond f a))</tt>.
iterWhile :: (b -> Bool) -> (a -> (b, a)) -> a -> [(b, a)]

-- | Repeat something while a condition on some state is true. Return the
--   last state (including the changes of the last transition, even if the
--   condition became false then).
repeatWhile :: (a -> (Bool, a)) -> a -> a

-- | Monadic version of <a>repeatWhile</a>.
repeatWhileM :: Monad m => (a -> m (Bool, a)) -> a -> m a

-- | A version of the trampoline function.
--   
--   The usual function iterates <tt>f :: a -&gt; Maybe a</tt> as long as
--   <tt>Just{}</tt> is returned, and returns the last value of <tt>a</tt>
--   upon <tt>Nothing</tt>.
--   
--   <tt>usualTrampoline f = trampolineWhile $ a -&gt; maybe (False,a)
--   (True,) (f a)</tt>.
--   
--   <tt>trampolineWhile</tt> is very similar to <tt>repeatWhile</tt>, only
--   that it discards the state on which the condition went <tt>False</tt>,
--   and returns the last state on which the condition was <tt>True</tt>.
trampolineWhile :: (a -> (Bool, a)) -> a -> a

-- | Monadic version of <a>trampolineWhile</a>.
trampolineWhileM :: Monad m => (a -> m (Bool, a)) -> a -> m a

-- | More general trampoline, which allows some final computation from
--   iteration state <tt>a</tt> into result type <tt>b</tt>.
trampoline :: (a -> Either b a) -> a -> b

-- | Monadic version of <a>trampoline</a>.
trampolineM :: Monad m => (a -> m (Either b a)) -> a -> m b

-- | Iteration to fixed-point.
--   
--   <tt>iterateUntil r f a0</tt> iterates endofunction <tt>f</tt>,
--   starting with <tt>a0</tt>, until <tt>r</tt> relates its result to its
--   input, i.e., <tt>f a <tt>r</tt> a</tt>.
--   
--   This is the generic pattern behind saturation algorithms.
--   
--   If <tt>f</tt> is monotone with regard to <tt>r</tt>, meaning <tt>a
--   <tt>r</tt> b</tt> implies <tt>f a <tt>r</tt> f b</tt>, and
--   <tt>f</tt>-chains starting with <tt>a0</tt> are finite then iteration
--   is guaranteed to terminate.
--   
--   A typical instance will work on sets, and <tt>r</tt> could be set
--   inclusion, and <tt>a0</tt> the empty set, and <tt>f</tt> the step
--   function of a saturation algorithm.
iterateUntil :: (a -> a -> Bool) -> (a -> a) -> a -> a

-- | Monadic version of <tt>applyUnless</tt>
applyUnlessM :: (IsBool b, Monad m) => m b -> (m a -> m a) -> m a -> m a

-- | <a>Maybe</a> version of <a>applyWhen</a>.
applyWhenJust :: Maybe b -> (b -> a -> a) -> a -> a

-- | <a>Maybe</a> version of <a>applyUnless</a>.
applyWhenNothing :: Maybe b -> (a -> a) -> a -> a

-- | <tt><a>on</a> b u x y</tt> runs the binary function <tt>b</tt>
--   <i>on</i> the results of applying unary function <tt>u</tt> to two
--   arguments <tt>x</tt> and <tt>y</tt>. From the opposite perspective, it
--   transforms two inputs and combines the outputs.
--   
--   <pre>
--   ((+) `<a>on</a>` f) x y = f x + f y
--   </pre>
--   
--   Typical usage: <tt><a>sortBy</a> (<a>compare</a> `on`
--   <a>fst</a>)</tt>.
--   
--   Algebraic properties:
--   
--   <ul>
--   <li><pre>(*) `on` <a>id</a> = (*) -- (if (*) ∉ {⊥, <a>const</a>
--   ⊥})</pre></li>
--   <li><pre>((*) `on` f) `on` g = (*) `on` (f . g)</pre></li>
--   <li><pre><a>flip</a> on f . <a>flip</a> on g = <a>flip</a> on (g .
--   f)</pre></li>
--   </ul>
on :: (b -> b -> c) -> (a -> b) -> a -> a -> c
infixl 0 `on`

module Agda.TypeChecking.SizedTypes.Utils
debug :: IORef Bool
setDebugging :: Bool -> IO ()
trace :: String -> a -> a
traceM :: Applicative f => String -> f ()
class Eq a => Top a
top :: Top a => a
isTop :: Top a => a -> Bool
class Plus a b c
plus :: Plus a b c => a -> b -> c
class MeetSemiLattice a
meet :: MeetSemiLattice a => a -> a -> a

-- | Semiring with idempotent <a>+</a> == dioid
class (MeetSemiLattice a, Top a) => Dioid a
compose :: Dioid a => a -> a -> a
unitCompose :: Dioid a => a
instance Agda.TypeChecking.SizedTypes.Utils.Plus GHC.Types.Int GHC.Types.Int GHC.Types.Int


-- | Utilities for functors.
module Agda.Utils.Functor

-- | Composition: pure function after functorial (monadic) function.
(<.>) :: Functor m => (b -> c) -> (a -> m b) -> a -> m c
infixr 9 <.>

-- | The true pure <tt>for</tt> loop. <a>for</a> is a misnomer, it should
--   be <tt>forA</tt>.
for :: Functor m => m a -> (a -> b) -> m b

-- | A decoration is a functor that is traversable into any functor.
--   
--   The <a>Functor</a> superclass is given because of the limitations of
--   the Haskell class system. <tt>traverseF</tt> actually implies
--   functoriality.
--   
--   Minimal complete definition: <tt>traverseF</tt> or
--   <tt>distributeF</tt>.
class Functor t => Decoration t

-- | <tt>traverseF</tt> is the defining property.
traverseF :: (Decoration t, Functor m) => (a -> m b) -> t a -> m (t b)

-- | Decorations commute into any functor.
distributeF :: (Decoration t, Functor m) => t (m a) -> m (t a)

-- | Any decoration is traversable with <tt>traverse = traverseF</tt>. Just
--   like any <a>Traversable</a> is a functor, so is any decoration, given
--   by just <tt>traverseF</tt>, a functor.
dmap :: Decoration t => (a -> b) -> t a -> t b

-- | Any decoration is a lens. <tt>set</tt> is a special case of
--   <tt>dmap</tt>.
dget :: Decoration t => t a -> a

-- | An infix synonym for <a>fmap</a>.
--   
--   The name of this operator is an allusion to <a>$</a>. Note the
--   similarities between their types:
--   
--   <pre>
--    ($)  ::              (a -&gt; b) -&gt;   a -&gt;   b
--   (&lt;$&gt;) :: Functor f =&gt; (a -&gt; b) -&gt; f a -&gt; f b
--   </pre>
--   
--   Whereas <a>$</a> is function application, <a>&lt;$&gt;</a> is function
--   application lifted over a <a>Functor</a>.
--   
--   <h4><b>Examples</b></h4>
--   
--   Convert from a <tt><a>Maybe</a> <a>Int</a></tt> to a <tt><a>Maybe</a>
--   <a>String</a></tt> using <a>show</a>:
--   
--   <pre>
--   &gt;&gt;&gt; show &lt;$&gt; Nothing
--   Nothing
--   
--   &gt;&gt;&gt; show &lt;$&gt; Just 3
--   Just "3"
--   </pre>
--   
--   Convert from an <tt><a>Either</a> <a>Int</a> <a>Int</a></tt> to an
--   <tt><a>Either</a> <a>Int</a></tt> <a>String</a> using <a>show</a>:
--   
--   <pre>
--   &gt;&gt;&gt; show &lt;$&gt; Left 17
--   Left 17
--   
--   &gt;&gt;&gt; show &lt;$&gt; Right 17
--   Right "17"
--   </pre>
--   
--   Double each element of a list:
--   
--   <pre>
--   &gt;&gt;&gt; (*2) &lt;$&gt; [1,2,3]
--   [2,4,6]
--   </pre>
--   
--   Apply <a>even</a> to the second element of a pair:
--   
--   <pre>
--   &gt;&gt;&gt; even &lt;$&gt; (2,2)
--   (2,True)
--   </pre>
(<$>) :: Functor f => (a -> b) -> f a -> f b
infixl 4 <$>

-- | Flipped version of <a>&lt;$</a>.
--   
--   <h4><b>Examples</b></h4>
--   
--   Replace the contents of a <tt><a>Maybe</a> <a>Int</a></tt> with a
--   constant <a>String</a>:
--   
--   <pre>
--   &gt;&gt;&gt; Nothing $&gt; "foo"
--   Nothing
--   
--   &gt;&gt;&gt; Just 90210 $&gt; "foo"
--   Just "foo"
--   </pre>
--   
--   Replace the contents of an <tt><a>Either</a> <a>Int</a>
--   <a>Int</a></tt> with a constant <a>String</a>, resulting in an
--   <tt><a>Either</a> <a>Int</a> <a>String</a></tt>:
--   
--   <pre>
--   &gt;&gt;&gt; Left 8675309 $&gt; "foo"
--   Left 8675309
--   
--   &gt;&gt;&gt; Right 8675309 $&gt; "foo"
--   Right "foo"
--   </pre>
--   
--   Replace each element of a list with a constant <a>String</a>:
--   
--   <pre>
--   &gt;&gt;&gt; [1,2,3] $&gt; "foo"
--   ["foo","foo","foo"]
--   </pre>
--   
--   Replace the second element of a pair with a constant <a>String</a>:
--   
--   <pre>
--   &gt;&gt;&gt; (1,2) $&gt; "foo"
--   (1,"foo")
--   </pre>
($>) :: Functor f => f a -> b -> f b
infixl 4 $>

-- | Flipped version of <a>&lt;$&gt;</a>.
--   
--   <pre>
--   (<a>&lt;&amp;&gt;</a>) = <a>flip</a> <a>fmap</a>
--   </pre>
--   
--   <h4><b>Examples</b></h4>
--   
--   Apply <tt>(+1)</tt> to a list, a <a>Just</a> and a <a>Right</a>:
--   
--   <pre>
--   &gt;&gt;&gt; Just 2 &lt;&amp;&gt; (+1)
--   Just 3
--   </pre>
--   
--   <pre>
--   &gt;&gt;&gt; [1,2,3] &lt;&amp;&gt; (+1)
--   [2,3,4]
--   </pre>
--   
--   <pre>
--   &gt;&gt;&gt; Right 3 &lt;&amp;&gt; (+1)
--   Right 4
--   </pre>
(<&>) :: Functor f => f a -> (a -> b) -> f b
infixl 1 <&>
instance Agda.Utils.Functor.Decoration Data.Functor.Identity.Identity
instance (Agda.Utils.Functor.Decoration d, Agda.Utils.Functor.Decoration t) => Agda.Utils.Functor.Decoration (Data.Functor.Compose.Compose d t)
instance Agda.Utils.Functor.Decoration ((,) a)


-- | Hash tables.
module Agda.Utils.HashTable

-- | Hash tables.
data HashTable k v

-- | An empty hash table.
empty :: IO (HashTable k v)

-- | Inserts the key and the corresponding value into the hash table.
insert :: (Eq k, Hashable k) => HashTable k v -> k -> v -> IO ()

-- | Tries to find a value corresponding to the key in the hash table.
lookup :: (Eq k, Hashable k) => HashTable k v -> k -> IO (Maybe v)

-- | Converts the hash table to a list.
--   
--   The order of the elements in the list is unspecified.
toList :: (Eq k, Hashable k) => HashTable k v -> IO [(k, v)]
keySet :: forall k v. Ord k => HashTable k v -> IO (Set k)


-- | ASTs for subset of GHC Haskell syntax.
module Agda.Utils.Haskell.Syntax
data Module
Module :: ModuleName -> [ModulePragma] -> [ImportDecl] -> [Decl] -> Module
data ModulePragma
LanguagePragma :: [Name] -> ModulePragma

-- | Unstructured pragma (Andreas, 2017-08-23, issue #2712).
OtherPragma :: String -> ModulePragma
data ImportDecl
ImportDecl :: ModuleName -> Bool -> Maybe (Bool, [ImportSpec]) -> ImportDecl
[importModule] :: ImportDecl -> ModuleName
[importQualified] :: ImportDecl -> Bool
[importSpecs] :: ImportDecl -> Maybe (Bool, [ImportSpec])
data ImportSpec
IVar :: Name -> ImportSpec
data Decl
TypeDecl :: Name -> [TyVarBind] -> Type -> Decl
DataDecl :: DataOrNew -> Name -> [TyVarBind] -> [ConDecl] -> [Deriving] -> Decl
TypeSig :: [Name] -> Type -> Decl

-- | Should not be used when <a>LocalBind</a> could be used.
FunBind :: [Match] -> Decl

-- | Should only be used in <tt>let</tt> or <tt>where</tt>.
LocalBind :: Strictness -> Name -> Rhs -> Decl
PatSyn :: Pat -> Pat -> Decl
FakeDecl :: String -> Decl
Comment :: String -> Decl
data DataOrNew
DataType :: DataOrNew
NewType :: DataOrNew
data ConDecl
ConDecl :: Name -> [(Maybe Strictness, Type)] -> ConDecl
data Strictness
Lazy :: Strictness
Strict :: Strictness
type Deriving = (QName, [Type])
data Binds
BDecls :: [Decl] -> Binds
data Rhs
UnGuardedRhs :: Exp -> Rhs
GuardedRhss :: [GuardedRhs] -> Rhs
data GuardedRhs
GuardedRhs :: [Stmt] -> Exp -> GuardedRhs
data Match
Match :: Name -> [Pat] -> Rhs -> Maybe Binds -> Match
data Type
TyForall :: [TyVarBind] -> Type -> Type
TyFun :: Type -> Type -> Type
TyCon :: QName -> Type
TyVar :: Name -> Type
TyApp :: Type -> Type -> Type
FakeType :: String -> Type
data Pat
PVar :: Name -> Pat
PLit :: Literal -> Pat
PAsPat :: Name -> Pat -> Pat
PWildCard :: Pat
PBangPat :: Pat -> Pat
PApp :: QName -> [Pat] -> Pat
PatTypeSig :: Pat -> Type -> Pat
PIrrPat :: Pat -> Pat
data Stmt
Qualifier :: Exp -> Stmt
Generator :: Pat -> Exp -> Stmt
data Exp
Var :: QName -> Exp
Con :: QName -> Exp
Lit :: Literal -> Exp
InfixApp :: Exp -> QOp -> Exp -> Exp
Ann :: Exp -> Type -> Exp
App :: Exp -> Exp -> Exp
Lambda :: [Pat] -> Exp -> Exp
Let :: Binds -> Exp -> Exp
If :: Exp -> Exp -> Exp -> Exp
Case :: Exp -> [Alt] -> Exp
ExpTypeSig :: Exp -> Type -> Exp
NegApp :: Exp -> Exp
FakeExp :: String -> Exp
data Alt
Alt :: Pat -> Rhs -> Maybe Binds -> Alt
data Literal
Int :: Integer -> Literal
Frac :: Rational -> Literal
Char :: Char -> Literal
String :: Text -> Literal
data ModuleName
ModuleName :: String -> ModuleName
data QName
Qual :: ModuleName -> Name -> QName
UnQual :: Name -> QName
data Name
Ident :: String -> Name
Symbol :: String -> Name
data QOp
QVarOp :: QName -> QOp
data TyVarBind
UnkindedVar :: Name -> TyVarBind
unit_con :: Exp
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.DataOrNew
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.Strictness
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.Literal
instance GHC.Classes.Ord Agda.Utils.Haskell.Syntax.ModuleName
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.ModuleName
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.Name
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.QName
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.QOp
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.TyVarBind
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.Type
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.Pat
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.ConDecl
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.Stmt
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.GuardedRhs
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.Binds
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.Alt
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.Exp
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.Rhs
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.Match
instance GHC.Classes.Eq Agda.Utils.Haskell.Syntax.Decl


-- | Strictification of Haskell code
module Agda.Compiler.MAlonzo.Strict

-- | The function <a>makeStrict</a> makes every function argument, case and
--   generator pattern, and <a>LocalBind</a> binding strict (except for
--   those patterns that are marked as irrefutable, and anything in a
--   <a>FakeDecl</a> or <a>FakeExp</a>). Note that only the outermost
--   patterns are made strict.
class MakeStrict a
makeStrict :: MakeStrict a => a -> a
instance Agda.Compiler.MAlonzo.Strict.MakeStrict a => Agda.Compiler.MAlonzo.Strict.MakeStrict [a]
instance Agda.Compiler.MAlonzo.Strict.MakeStrict a => Agda.Compiler.MAlonzo.Strict.MakeStrict (GHC.Maybe.Maybe a)
instance Agda.Compiler.MAlonzo.Strict.MakeStrict Agda.Utils.Haskell.Syntax.Module
instance Agda.Compiler.MAlonzo.Strict.MakeStrict Agda.Utils.Haskell.Syntax.Decl
instance Agda.Compiler.MAlonzo.Strict.MakeStrict Agda.Utils.Haskell.Syntax.Match
instance Agda.Compiler.MAlonzo.Strict.MakeStrict Agda.Utils.Haskell.Syntax.Pat
instance Agda.Compiler.MAlonzo.Strict.MakeStrict Agda.Utils.Haskell.Syntax.Binds
instance Agda.Compiler.MAlonzo.Strict.MakeStrict Agda.Utils.Haskell.Syntax.Rhs
instance Agda.Compiler.MAlonzo.Strict.MakeStrict Agda.Utils.Haskell.Syntax.GuardedRhs
instance Agda.Compiler.MAlonzo.Strict.MakeStrict Agda.Utils.Haskell.Syntax.Stmt
instance Agda.Compiler.MAlonzo.Strict.MakeStrict Agda.Utils.Haskell.Syntax.Exp
instance Agda.Compiler.MAlonzo.Strict.MakeStrict Agda.Utils.Haskell.Syntax.Alt


-- | Array utilities.
module Agda.Utils.IArray

-- | Returns <a>Just</a> the element of an immutable array at the specified
--   index, or <a>Nothing</a> if the index is out of bounds.
(!?) :: (IArray a e, Ix i) => a i e -> i -> Maybe e


-- | Binary IO.
module Agda.Utils.IO.Binary

-- | Returns a close function for the file together with the contents.
readBinaryFile' :: FilePath -> IO (ByteString, IO ())

module Agda.Utils.IO.Directory

-- | <tt>copyDirContent src dest</tt> recursively copies directory
--   <tt>src</tt> onto <tt>dest</tt>.
--   
--   First, a to-do list of copy actions is created. Then, the to-do list
--   is carried out.
--   
--   This avoids copying files we have just created again, which can happen
--   if <tt>src</tt> and <tt>dest</tt> are not disjoint. (See issue #2705.)
copyDirContent :: FilePath -> FilePath -> IO ()

-- | <tt>copyIfChanged src dst</tt> makes sure that <tt>dst</tt> exists and
--   has the same content as <tt>dst</tt>.
copyIfChanged :: FilePath -> FilePath -> IO ()


-- | Common syntax highlighting functions for Emacs and JSON
module Agda.Utils.IO.TempFile

-- | Creates a temporary file, writes some stuff, and returns the filepath
writeToTempFile :: String -> IO FilePath


-- | Text IO using the UTF8 character encoding.
module Agda.Utils.IO.UTF8

-- | A kind of exception that can be thrown by <a>readTextFile</a> and
--   <a>readFile</a>.
data ReadException

-- | Reads a UTF8-encoded text file and converts many character sequences
--   which may be interpreted as line or paragraph separators into 'n'.
--   
--   If the file cannot be decoded, then a <a>ReadException</a> is raised.
readTextFile :: FilePath -> IO Text

-- | Reads a UTF8-encoded text file and converts many character sequences
--   which may be interpreted as line or paragraph separators into 'n'.
--   
--   If the file cannot be decoded, then a <a>ReadException</a> is raised.
readFile :: FilePath -> IO String

-- | Writes a UTF8-encoded text file. The native convention for line
--   endings is used.
writeFile :: FilePath -> String -> IO ()

-- | Writes a UTF8-encoded text file. The native convention for line
--   endings is used.
writeTextToFile :: FilePath -> Text -> IO ()
instance GHC.Show.Show Agda.Utils.IO.UTF8.ReadException
instance GHC.Exception.Type.Exception Agda.Utils.IO.UTF8.ReadException


-- | Utilities for Data.IORef.
module Agda.Utils.IORef

-- | Read <a>IORef</a>, modify it strictly, and return old value.
readModifyIORef' :: IORef a -> (a -> a) -> IO a


-- | An interface for reporting "impossible" errors
module Agda.Utils.Impossible

-- | "Impossible" errors, annotated with a file name and a line number
--   corresponding to the source code location of the error.
data Impossible

-- | We reached a program point which should be unreachable.
Impossible :: CallStack -> Impossible

-- | <tt>Impossible</tt> with a different error message. Used when we reach
--   a program point which can in principle be reached, but not for a
--   certain run.
Unreachable :: CallStack -> Impossible

-- | We reached a program point without all the required primitives or
--   BUILTIN to proceed forward. <tt>ImpMissingDefinitions neededDefs
--   forThis</tt>
ImpMissingDefinitions :: [String] -> String -> Impossible

-- | Abort by throwing an "impossible" error. You should not use this
--   function directly. Instead use <b>IMPOSSIBLE</b>
throwImpossible :: Impossible -> a

-- | Monads in which we can catch an "impossible" error, if possible.
class CatchImpossible m

-- | Catch any <a>Impossible</a> exception.
catchImpossible :: CatchImpossible m => m a -> (Impossible -> m a) -> m a

-- | Catch only <a>Impossible</a> exceptions selected by the filter.
catchImpossibleJust :: CatchImpossible m => (Impossible -> Maybe b) -> m a -> (b -> m a) -> m a

-- | Version of <a>catchImpossible</a> with argument order suiting short
--   handlers.
handleImpossible :: CatchImpossible m => (Impossible -> m a) -> m a -> m a

-- | Version of <a>catchImpossibleJust</a> with argument order suiting
--   short handlers.
handleImpossibleJust :: CatchImpossible m => (Impossible -> Maybe b) -> (b -> m a) -> m a -> m a

-- | Throw an <a>Impossible</a> error reporting the *caller's* call site.
__IMPOSSIBLE__ :: HasCallStack => a
impossible :: HasCallStack => Impossible

-- | Throw an <a>Unreachable</a> error reporting the *caller's* call site.
--   Note that this call to "withFileAndLine" will be filtered out due its
--   filter on the srcLocModule.
__UNREACHABLE__ :: HasCallStack => a
instance Agda.Utils.Impossible.CatchImpossible GHC.Types.IO
instance GHC.Classes.Eq Agda.Utils.Impossible.Impossible
instance GHC.Classes.Ord Agda.Utils.Impossible.Impossible
instance Control.DeepSeq.NFData Agda.Utils.Impossible.Impossible
instance GHC.Show.Show Agda.Utils.Impossible.Impossible
instance GHC.Exception.Type.Exception Agda.Utils.Impossible.Impossible


-- | An empty type with some useful instances.
module Agda.Utils.Empty
data Empty
absurd :: Empty -> a

-- | <tt>toImpossible e</tt> extracts the <tt>Impossible</tt> value raised
--   via <tt><b>IMPOSSIBLE</b></tt> to create the element <tt>e</tt> of
--   type <tt>Empty</tt>. It proceeds by evaluating <tt>e</tt> to weak head
--   normal form and catching the exception. We are forced to wrap things
--   in a <tt>Maybe</tt> because of <tt>catchImpossible</tt>'s type.
toImpossible :: Empty -> IO Impossible
instance Control.DeepSeq.NFData Agda.Utils.Empty.Empty
instance GHC.Classes.Eq Agda.Utils.Empty.Empty
instance GHC.Classes.Ord Agda.Utils.Empty.Empty
instance GHC.Show.Show Agda.Utils.Empty.Empty


-- | Representation of <tt><tt>Set</tt> <a>Bool</a></tt> as a 4-element
--   enum type.
--   
--   All operations in constant time and space.
--   
--   Mimics the interface of <a>Set</a>.
--   
--   Import as: <tt> import qualified Agda.Utils.BoolSet as BoolSet import
--   Agda.Utils.BoolSet (BoolSet) </tt>
module Agda.Utils.BoolSet

-- | Isomorphic to <tt><tt>Set</tt> <a>Bool</a></tt>.
data BoolSet
(\\) :: BoolSet -> BoolSet -> BoolSet
complement :: BoolSet -> BoolSet
delete :: Bool -> BoolSet -> BoolSet
difference :: BoolSet -> BoolSet -> BoolSet
elems :: BoolSet -> [Bool]

-- | The empty set.
empty :: BoolSet
fromList :: [Bool] -> BoolSet
fromAscList :: [Bool] -> BoolSet
fromDistinctAscList :: [Bool] -> BoolSet
insert :: Bool -> BoolSet -> BoolSet
intersection :: BoolSet -> BoolSet -> BoolSet
isSubsetOf :: BoolSet -> BoolSet -> Bool
lookupMin :: BoolSet -> Maybe Bool
member :: Bool -> BoolSet -> Bool

-- | <tt>not . member b</tt>.
notMember :: Bool -> BoolSet -> Bool
null :: BoolSet -> Bool

-- | A singleton set.
singleton :: Bool -> BoolSet
size :: BoolSet -> Int
toList :: BoolSet -> [Bool]
toAscList :: BoolSet -> [Bool]

-- | <tt>toSingleton s == Just b</tt> iff <tt>s == singleton b</tt>.
toSingleton :: BoolSet -> Maybe Bool

-- | The full set.
total :: BoolSet
union :: BoolSet -> BoolSet -> BoolSet
instance GHC.Enum.Bounded Agda.Utils.BoolSet.BoolSet
instance GHC.Enum.Enum Agda.Utils.BoolSet.BoolSet
instance GHC.Show.Show Agda.Utils.BoolSet.BoolSet
instance GHC.Classes.Ord Agda.Utils.BoolSet.BoolSet
instance GHC.Classes.Eq Agda.Utils.BoolSet.BoolSet


-- | A simple overlay over Data.Map to manage unordered sets with
--   duplicates.
module Agda.Utils.Bag

-- | A set with duplicates. Faithfully stores elements which are equal with
--   regard to (==).
newtype Bag a
Bag :: Map a [a] -> Bag a

-- | The list contains all occurrences of <tt>a</tt> (not just the
--   duplicates!). Hence, the invariant: the list is never empty.
[bag] :: Bag a -> Map a [a]

-- | Is the bag empty?
null :: Bag a -> Bool

-- | Number of elements in the bag. Duplicates count. O(n).
size :: Bag a -> Int

-- | <tt>(bag ! a)</tt> finds all elements equal to <tt>a</tt>. O(log n).
--   Total function, returns <tt>[]</tt> if none are.
(!) :: Ord a => Bag a -> a -> [a]

-- | O(log n).
member :: Ord a => a -> Bag a -> Bool

-- | O(log n).
notMember :: Ord a => a -> Bag a -> Bool

-- | Return the multiplicity of the given element. O(log n + count _ _).
count :: Ord a => a -> Bag a -> Int

-- | O(1)
empty :: Bag a

-- | O(1)
singleton :: a -> Bag a
union :: Ord a => Bag a -> Bag a -> Bag a
unions :: Ord a => [Bag a] -> Bag a

-- | <pre>
--   insert a b = union b (singleton a)
--   </pre>
insert :: Ord a => a -> Bag a -> Bag a

-- | <pre>
--   fromList = unions . map singleton
--   </pre>
fromList :: Ord a => [a] -> Bag a

-- | Returns the elements of the bag, grouped by equality (==).
groups :: Bag a -> [[a]]

-- | Returns the bag, with duplicates.
toList :: Bag a -> [a]

-- | Returns the bag without duplicates.
keys :: Bag a -> [a]

-- | Returns the bag, with duplicates.
elems :: Bag a -> [a]
toAscList :: Bag a -> [a]
map :: Ord b => (a -> b) -> Bag a -> Bag b
traverse' :: forall a b m. (Applicative m, Ord b) => (a -> m b) -> Bag a -> m (Bag b)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.Utils.Bag.Bag a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Utils.Bag.Bag a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.Utils.Bag.Bag a)
instance GHC.Classes.Ord a => GHC.Base.Semigroup (Agda.Utils.Bag.Bag a)
instance GHC.Classes.Ord a => GHC.Base.Monoid (Agda.Utils.Bag.Bag a)
instance Data.Foldable.Foldable Agda.Utils.Bag.Bag


-- | Possibly infinite sets of integers (but with finitely many consecutive
--   segments). Used for checking guard coverage in int/nat cases in the
--   treeless compiler.
module Agda.Utils.IntSet.Infinite

-- | Represents a set of integers. Invariants: - All cannot be the argument
--   to <a>Below</a> or <a>Above</a> - at most one <tt>IntsBelow</tt> - at
--   most one <tt>IntsAbove</tt> - if `Below lo` and `Below hi`, then `lo
--   &lt; hi` - if `Below lo .. (Some xs)` then `all (&gt; lo) xs` - if
--   `Above hi .. (Some xs)` then `all (&lt; hi - 1) xs`
data IntSet

-- | No integers.
empty :: IntSet

-- | All integers.
full :: IntSet

-- | All integers `&lt; n`
below :: Integer -> IntSet

-- | All integers `&gt;= n`
above :: Integer -> IntSet

-- | A single integer.
singleton :: Integer -> IntSet
difference :: IntSet -> IntSet -> IntSet

-- | Membership
member :: Integer -> IntSet -> Bool

-- | If finite, return the list of elements.
toFiniteList :: IntSet -> Maybe [Integer]

-- | Invariant.
invariant :: IntSet -> Bool
instance GHC.Show.Show Agda.Utils.IntSet.Infinite.IntSet
instance GHC.Classes.Eq Agda.Utils.IntSet.Infinite.IntSet
instance GHC.Base.Semigroup Agda.Utils.IntSet.Infinite.IntSet
instance GHC.Base.Monoid Agda.Utils.IntSet.Infinite.IntSet


-- | A cut-down implementation of lenses, with names taken from Edward
--   Kmett's lens package.
module Agda.Utils.Lens

-- | Van Laarhoven style homogeneous lenses. Mnemoic: "Lens outer inner",
--   same type argument order as 'get :: o -&gt; i'.
type Lens' o i = forall f. Functor f => (i -> f i) -> o -> f o
type LensGet o i = o -> i
type LensSet o i = i -> o -> o
type LensMap o i = (i -> i) -> o -> o

-- | Access a map value at a given key.
key :: Ord k => k -> Lens' (Map k v) (Maybe v)

-- | Write a part of the state.
(.=) :: MonadState o m => Lens' o i -> i -> m ()
infix 4 .=

-- | Modify inner part <tt>i</tt> of structure <tt>o</tt> using a function
--   <tt>i -&gt; i</tt>.
over :: Lens' o i -> LensMap o i

-- | Set inner part <tt>i</tt> of structure <tt>o</tt> as designated by
--   <tt>Lens' o i</tt>.
set :: Lens' o i -> LensSet o i

-- | Get inner part <tt>i</tt> of structure <tt>o</tt> as designated by
--   <tt>Lens' o i</tt>.
(^.) :: o -> Lens' o i -> i
infixl 8 ^.
lFst :: Lens' (a, b) a
lSnd :: Lens' (a, b) b

-- | Build a lens out of an isomorphism.
iso :: (o -> i) -> (i -> o) -> Lens' o i

-- | Focus on a part of the state for a stateful computation.
focus :: Monad m => Lens' o i -> StateT i m a -> StateT o m a

-- | Read a part of the state.
use :: MonadState o m => Lens' o i -> m i

-- | Modify a part of the state.
(%=) :: MonadState o m => Lens' o i -> (i -> i) -> m ()
infix 4 %=

-- | Modify a part of the state monadically.
(%==) :: MonadState o m => Lens' o i -> (i -> m i) -> m ()
infix 4 %==

-- | Modify a part of the state monadically, and return some result.
(%%=) :: MonadState o m => Lens' o i -> (i -> m (i, r)) -> m r
infix 4 %%=

-- | Modify a part of the state locally.
locallyState :: MonadState o m => Lens' o i -> (i -> i) -> m r -> m r

-- | Ask for part of read-only state.
view :: MonadReader o m => Lens' o i -> m i

-- | Modify a part of the state in a subcomputation.
locally :: MonadReader o m => Lens' o i -> (i -> i) -> m a -> m a
locally' :: ((o -> o) -> m a -> m a) -> Lens' o i -> (i -> i) -> m a -> m a

-- | Focus on given element in a set.
contains :: Ord k => k -> Lens' (Set k) Bool

-- | Flipped version of <a>&lt;$&gt;</a>.
--   
--   <pre>
--   (<a>&lt;&amp;&gt;</a>) = <a>flip</a> <a>fmap</a>
--   </pre>
--   
--   <h4><b>Examples</b></h4>
--   
--   Apply <tt>(+1)</tt> to a list, a <a>Just</a> and a <a>Right</a>:
--   
--   <pre>
--   &gt;&gt;&gt; Just 2 &lt;&amp;&gt; (+1)
--   Just 3
--   </pre>
--   
--   <pre>
--   &gt;&gt;&gt; [1,2,3] &lt;&amp;&gt; (+1)
--   [2,3,4]
--   </pre>
--   
--   <pre>
--   &gt;&gt;&gt; Right 3 &lt;&amp;&gt; (+1)
--   Right 4
--   </pre>
(<&>) :: Functor f => f a -> (a -> b) -> f b
infixl 1 <&>

module Agda.Utils.IndexedList

-- | Existential wrapper for indexed types.
data Some :: (k -> Type) -> Type
[Some] :: f i -> Some f

-- | Unpacking a wrapped value.
withSome :: Some b -> (forall i. b i -> a) -> a

-- | Lists indexed by a type-level list. A value of type <tt>All p
--   [x₁..xₙ]</tt> is a sequence of values of types <tt>p x₁</tt>, ..,
--   <tt>p xₙ</tt>.
data All :: (x -> Type) -> [x] -> Type
[Nil] :: All p '[]
[Cons] :: p x -> All p xs -> All p (x ': xs)

-- | Constructing an indexed list from a plain list.
makeAll :: (a -> Some b) -> [a] -> Some (All b)

-- | Turning an indexed list back into a plain list.
forgetAll :: (forall x. b x -> a) -> All b xs -> [a]

-- | An index into a type-level list.
data Index :: [x] -> x -> Type
[Zero] :: Index (x ': xs) x
[Suc] :: Index xs x -> Index (y ': xs) x

-- | Indices are just natural numbers.
forgetIndex :: Index xs x -> Int

-- | Mapping over an indexed list.
mapWithIndex :: (forall x. Index xs x -> p x -> q x) -> All p xs -> All q xs

-- | If you have an index you can get a lens for the given element.
lIndex :: Index xs x -> Lens' (All p xs) (p x)

-- | Looking up an element in an indexed list.
lookupIndex :: All p xs -> Index xs x -> p x

-- | All indices into an indexed list.
allIndices :: All p xs -> All (Index xs) xs


-- | Examples how to use <a>Agda.Utils.Lens</a>.
module Agda.Utils.Lens.Examples
data Record a b
Record :: a -> b -> Record a b
[field1] :: Record a b -> a
[field2] :: Record a b -> b

-- | (View source:) This is how you implement a lens for a record field.
lensField1 :: Lens' (Record a b) a
lensField2 :: Lens' (Record a b) b

module Agda.Utils.Map

-- | Update monadically the value at one position (must exist!).
adjustM :: (Functor f, Ord k) => (v -> f v) -> k -> Map k v -> f (Map k v)

-- | Wrapper for <a>adjustM</a> for convenience.
adjustM' :: (Functor f, Ord k) => (v -> f (a, v)) -> k -> Map k v -> f (a, Map k v)

-- | Filter a map based on the keys.
filterKeys :: (k -> Bool) -> Map k a -> Map k a


-- | Extend <a>Maybe</a> by common operations for the <a>Maybe</a> type.
--   
--   Note: since this module is usually imported unqualified, we do not use
--   short names, but all names contain <a>Maybe</a>, <a>Just</a>, or
--   'Nothing.
module Agda.Utils.Maybe

-- | Version of <a>mapMaybe</a> with different argument ordering.
forMaybe :: [a] -> (a -> Maybe b) -> [b]

-- | Retain object when tag is <a>True</a>.
boolToMaybe :: Bool -> a -> Maybe a

-- | Monadic version of <a>caseMaybe</a>. That is, <a>maybeM</a> with a
--   different argument ordering.
caseMaybeM :: Monad m => m (Maybe a) -> m b -> (a -> m b) -> m b

-- | <a>caseMaybe</a> without the <a>Just</a> case.
whenNothing :: Monoid m => Maybe a -> m -> m

-- | Monadic version of <a>fromMaybe</a>.
fromMaybeM :: Monad m => m a -> m (Maybe a) -> m a

-- | Filtering a singleton list.
--   
--   <pre>
--   filterMaybe p a = <a>listToMaybe</a> (<a>filter</a> p [a])
--   </pre>
filterMaybe :: (a -> Bool) -> a -> Maybe a

-- | Lazy version of <tt>allJust <a>.</a> sequence</tt>. (<tt>allJust =
--   mapM</tt> for the <tt>Maybe</tt> monad.) Only executes monadic effect
--   while <tt>isJust</tt>.
allJustM :: Monad m => [m (Maybe a)] -> m (Maybe [a])

-- | <a>caseMaybeM</a> without the <a>Just</a> case.
whenNothingM :: Monad m => m (Maybe a) -> m () -> m ()

-- | A more telling name for <a>forM_</a> for the <a>Maybe</a> collection
--   type. Or: <a>caseMaybe</a> without the <a>Nothing</a> case.
whenJust :: Monad m => Maybe a -> (a -> m ()) -> m ()

-- | <tt>unionWith</tt> for collections of size &lt;= 1.
unionMaybeWith :: (a -> a -> a) -> Maybe a -> Maybe a -> Maybe a

-- | <tt>unionsWith</tt> for collections of size &lt;= 1.
unionsMaybeWith :: (a -> a -> a) -> [Maybe a] -> Maybe a

-- | Unzipping a list of length &lt;= 1.
unzipMaybe :: Maybe (a, b) -> (Maybe a, Maybe b)

-- | Version of <a>maybe</a> with different argument ordering. Often, we
--   want to case on a <a>Maybe</a>, do something interesting in the
--   <a>Just</a> case, but only a default action in the <a>Nothing</a>
--   case. Then, the argument ordering of <tt>caseMaybe</tt> is preferable.
--   
--   <pre>
--   caseMaybe m d f = flip (maybe d) m f
--   </pre>
caseMaybe :: Maybe a -> b -> (a -> b) -> b

-- | <a>caseMaybe</a> with flipped branches.
ifJust :: Maybe a -> (a -> b) -> b -> b

-- | Monadic version of <a>maybe</a>.
maybeM :: Monad m => m b -> (a -> m b) -> m (Maybe a) -> m b

-- | <a>caseMaybeM</a> with flipped branches.
ifJustM :: Monad m => m (Maybe a) -> (a -> m b) -> m b -> m b

-- | <a>caseMaybeM</a> without the <a>Nothing</a> case.
whenJustM :: Monad m => m (Maybe a) -> (a -> m ()) -> m ()

-- | Lift a maybe to an Alternative.
liftMaybe :: Alternative f => Maybe a -> f a

-- | Like <a>span</a>, takes the prefix of a list satisfying a predicate.
--   Returns the run of <a>Just</a>s until the first <a>Nothing</a>, and
--   the tail of the list.
spanMaybe :: (a -> Maybe b) -> [a] -> ([b], [a])

module Agda.Utils.Memo

-- | Simple, non-reentrant memoisation.
memo :: MonadState s m => Lens' s (Maybe a) -> m a -> m a

-- | Recursive memoisation, second argument is the value you get on
--   recursive calls.
memoRec :: MonadState s m => Lens' s (Maybe a) -> a -> m a -> m a
memoUnsafe :: Ord a => (a -> b) -> a -> b
memoUnsafeH :: (Eq a, Hashable a) => (a -> b) -> a -> b


-- | More monoids.
module Agda.Utils.Monoid

-- | Maximum of on-negative (small) natural numbers.
newtype MaxNat
MaxNat :: Int -> MaxNat
[getMaxNat] :: MaxNat -> Int
instance GHC.Enum.Enum Agda.Utils.Monoid.MaxNat
instance GHC.Show.Show Agda.Utils.Monoid.MaxNat
instance GHC.Classes.Ord Agda.Utils.Monoid.MaxNat
instance GHC.Classes.Eq Agda.Utils.Monoid.MaxNat
instance GHC.Num.Num Agda.Utils.Monoid.MaxNat
instance GHC.Base.Semigroup Agda.Utils.Monoid.MaxNat
instance GHC.Base.Monoid Agda.Utils.Monoid.MaxNat

module Agda.Utils.PartialOrd

-- | The result of comparing two things (of the same type).
data PartialOrdering

-- | Less than.
POLT :: PartialOrdering

-- | Less or equal than.
POLE :: PartialOrdering

-- | Equal
POEQ :: PartialOrdering

-- | Greater or equal.
POGE :: PartialOrdering

-- | Greater than.
POGT :: PartialOrdering

-- | No information (incomparable).
POAny :: PartialOrdering

-- | Comparing the information content of two elements of
--   <a>PartialOrdering</a>. More precise information is smaller.
--   
--   Includes equality: <tt>x <a>leqPO</a> x == True</tt>.
leqPO :: PartialOrdering -> PartialOrdering -> Bool

-- | Opposites.
--   
--   <tt>related a po b</tt> iff <tt>related b (oppPO po) a</tt>.
oppPO :: PartialOrdering -> PartialOrdering

-- | Combining two pieces of information (picking the least information).
--   Used for the dominance ordering on tuples.
--   
--   <tt>orPO</tt> is associative, commutative, and idempotent.
--   <tt>orPO</tt> has dominant element <tt>POAny</tt>, but no neutral
--   element.
orPO :: PartialOrdering -> PartialOrdering -> PartialOrdering

-- | Chains (transitivity) <tt>x R y S z</tt>.
--   
--   <tt>seqPO</tt> is associative, commutative, and idempotent.
--   <tt>seqPO</tt> has dominant element <tt>POAny</tt> and neutral element
--   (unit) <tt>POEQ</tt>.
seqPO :: PartialOrdering -> PartialOrdering -> PartialOrdering

-- | Embed <a>Ordering</a>.
fromOrdering :: Ordering -> PartialOrdering

-- | Represent a non-empty disjunction of <a>Ordering</a>s as
--   <a>PartialOrdering</a>.
fromOrderings :: [Ordering] -> PartialOrdering

-- | A <a>PartialOrdering</a> information is a disjunction of
--   <a>Ordering</a> informations.
toOrderings :: PartialOrdering -> [Ordering]
type Comparable a = a -> a -> PartialOrdering

-- | Decidable partial orderings.
class PartialOrd a
comparable :: PartialOrd a => Comparable a

-- | Any <a>Ord</a> is a <a>PartialOrd</a>.
comparableOrd :: Ord a => Comparable a

-- | Are two elements related in a specific way?
--   
--   <tt>related a o b</tt> holds iff <tt>comparable a b</tt> is contained
--   in <tt>o</tt>.
related :: PartialOrd a => a -> PartialOrdering -> a -> Bool

-- | Pointwise comparison wrapper.
newtype Pointwise a
Pointwise :: a -> Pointwise a
[pointwise] :: Pointwise a -> a

-- | Inclusion comparison wrapper.
newtype Inclusion a
Inclusion :: a -> Inclusion a
[inclusion] :: Inclusion a -> a
instance GHC.Enum.Bounded Agda.Utils.PartialOrd.PartialOrdering
instance GHC.Enum.Enum Agda.Utils.PartialOrd.PartialOrdering
instance GHC.Show.Show Agda.Utils.PartialOrd.PartialOrdering
instance GHC.Classes.Eq Agda.Utils.PartialOrd.PartialOrdering
instance GHC.Base.Functor Agda.Utils.PartialOrd.Pointwise
instance GHC.Show.Show a => GHC.Show.Show (Agda.Utils.PartialOrd.Pointwise a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Utils.PartialOrd.Pointwise a)
instance GHC.Base.Functor Agda.Utils.PartialOrd.Inclusion
instance GHC.Show.Show a => GHC.Show.Show (Agda.Utils.PartialOrd.Inclusion a)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.Utils.PartialOrd.Inclusion a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Utils.PartialOrd.Inclusion a)
instance GHC.Classes.Ord a => Agda.Utils.PartialOrd.PartialOrd (Agda.Utils.PartialOrd.Inclusion [a])
instance GHC.Classes.Ord a => Agda.Utils.PartialOrd.PartialOrd (Agda.Utils.PartialOrd.Inclusion (Data.Set.Internal.Set a))
instance Agda.Utils.PartialOrd.PartialOrd a => Agda.Utils.PartialOrd.PartialOrd (Agda.Utils.PartialOrd.Pointwise [a])
instance Agda.Utils.PartialOrd.PartialOrd GHC.Types.Int
instance Agda.Utils.PartialOrd.PartialOrd GHC.Num.Integer.Integer
instance Agda.Utils.PartialOrd.PartialOrd ()
instance Agda.Utils.PartialOrd.PartialOrd a => Agda.Utils.PartialOrd.PartialOrd (GHC.Maybe.Maybe a)
instance (Agda.Utils.PartialOrd.PartialOrd a, Agda.Utils.PartialOrd.PartialOrd b) => Agda.Utils.PartialOrd.PartialOrd (Data.Either.Either a b)
instance (Agda.Utils.PartialOrd.PartialOrd a, Agda.Utils.PartialOrd.PartialOrd b) => Agda.Utils.PartialOrd.PartialOrd (a, b)
instance Agda.Utils.PartialOrd.PartialOrd Agda.Utils.PartialOrd.PartialOrdering
instance GHC.Base.Semigroup Agda.Utils.PartialOrd.PartialOrdering
instance GHC.Base.Monoid Agda.Utils.PartialOrd.PartialOrdering


-- | Partially ordered monoids.
module Agda.Utils.POMonoid

-- | Partially ordered semigroup.
--   
--   Law: composition must be monotone.
--   
--   <pre>
--   related x POLE x' &amp;&amp; related y POLE y' ==&gt;
--   related (x &lt;&gt; y) POLE (x' &lt;&gt; y')
--   </pre>
class (PartialOrd a, Semigroup a) => POSemigroup a

-- | Partially ordered monoid.
--   
--   Law: composition must be monotone.
--   
--   <pre>
--   related x POLE x' &amp;&amp; related y POLE y' ==&gt;
--   related (x &lt;&gt; y) POLE (x' &lt;&gt; y')
--   </pre>
class (PartialOrd a, Semigroup a, Monoid a) => POMonoid a

-- | Completing POMonoids with inverses to form a Galois connection.
--   
--   Law: composition and inverse composition form a Galois connection.
--   
--   <pre>
--   related (inverseCompose p x) POLE y <a>==</a> related x POLE (p &lt;&gt; y)
--   </pre>
class POMonoid a => LeftClosedPOMonoid a
inverseCompose :: LeftClosedPOMonoid a => a -> a -> a

-- | <tt>hasLeftAdjoint x</tt> checks whether <tt>x^-1 := x
--   <a>inverseCompose</a> mempty</tt> is such that <tt>x
--   <a>inverseCompose</a> y == x^-1 &lt;&gt; y</tt> for any <tt>y</tt>.
hasLeftAdjoint :: LeftClosedPOMonoid a => a -> Bool

module Agda.Utils.Pointer
data Ptr a
newPtr :: a -> Ptr a
derefPtr :: Ptr a -> a
setPtr :: a -> Ptr a -> Ptr a
updatePtr :: (a -> a) -> Ptr a -> Ptr a

-- | If <tt>f a</tt> contains many copies of <tt>a</tt> they will all be
--   the same pointer in the result. If the function is well-behaved (i.e.
--   preserves the implicit equivalence, this shouldn't matter).
updatePtrM :: Functor f => (a -> f a) -> Ptr a -> f (Ptr a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.Utils.Pointer.Ptr a)
instance GHC.Base.Functor Agda.Utils.Pointer.Ptr
instance Data.Foldable.Foldable Agda.Utils.Pointer.Ptr
instance Data.Traversable.Traversable Agda.Utils.Pointer.Ptr
instance GHC.Classes.Eq (Agda.Utils.Pointer.Ptr a)
instance GHC.Classes.Ord (Agda.Utils.Pointer.Ptr a)
instance Data.Hashable.Class.Hashable (Agda.Utils.Pointer.Ptr a)
instance Control.DeepSeq.NFData (Agda.Utils.Pointer.Ptr a)

module Agda.Utils.SemiRing

-- | Semirings (<a>https://en.wikipedia.org/wiki/Semiring</a>).
class SemiRing a
ozero :: SemiRing a => a
oone :: SemiRing a => a
oplus :: SemiRing a => a -> a -> a
otimes :: SemiRing a => a -> a -> a

-- | Star semirings
--   (<a>https://en.wikipedia.org/wiki/Semiring#Star_semirings</a>).
class SemiRing a => StarSemiRing a
ostar :: StarSemiRing a => a -> a
instance Agda.Utils.SemiRing.StarSemiRing ()
instance Agda.Utils.SemiRing.StarSemiRing a => Agda.Utils.SemiRing.StarSemiRing (GHC.Maybe.Maybe a)
instance Agda.Utils.SemiRing.SemiRing ()
instance Agda.Utils.SemiRing.SemiRing a => Agda.Utils.SemiRing.SemiRing (GHC.Maybe.Maybe a)


-- | Some semigroup instances used in several places
module Agda.Utils.Semigroup

-- | The class of semigroups (types with an associative binary operation).
--   
--   Instances should satisfy the following:
--   
--   <ul>
--   <li><i>Associativity</i> <tt>x <a>&lt;&gt;</a> (y <a>&lt;&gt;</a> z) =
--   (x <a>&lt;&gt;</a> y) <a>&lt;&gt;</a> z</tt></li>
--   </ul>
--   
--   You can alternatively define <a>sconcat</a> instead of
--   (<a>&lt;&gt;</a>), in which case the laws are:
--   
--   <ul>
--   <li><i>Unit</i> <tt><a>sconcat</a> (<a>pure</a> x) = x</tt></li>
--   <li><i>Multiplication</i> <tt><a>sconcat</a> (<a>join</a> xss) =
--   <a>sconcat</a> (<a>fmap</a> <a>sconcat</a> xss)</tt></li>
--   </ul>
class () => Semigroup a

-- | An associative operation.
--   
--   <pre>
--   &gt;&gt;&gt; [1,2,3] &lt;&gt; [4,5,6]
--   [1,2,3,4,5,6]
--   </pre>
(<>) :: Semigroup a => a -> a -> a
infixr 6 <>
instance (GHC.Base.Applicative m, GHC.Base.Semigroup doc) => GHC.Base.Semigroup (Control.Monad.Trans.Reader.ReaderT s m doc)
instance (GHC.Base.Monad m, GHC.Base.Semigroup doc) => GHC.Base.Semigroup (Control.Monad.Trans.State.Lazy.StateT s m doc)

module Agda.Utils.Suffix

-- | Is the character one of the subscripts <tt>'₀'</tt>-<tt>'₉'</tt>?
isSubscriptDigit :: Char -> Bool

-- | Converts <tt>'0'</tt>-<tt>'9'</tt> to <tt>'₀'</tt>-<tt>'₉'</tt>
--   
--   Precondition: The digit needs to be in range.
toSubscriptDigit :: Char -> Char

-- | Converts <tt>'₀'</tt>-<tt>'₉'</tt> to <tt>'0'</tt>-<tt>'9'</tt>.
--   
--   Precondition: The digit needs to be in range.
fromSubscriptDigit :: Char -> Char

-- | Classification of identifier variants.
data Suffix

-- | Identifier ends in <tt>Integer</tt> many primes.
Prime :: Integer -> Suffix

-- | Identifier ends in number <tt>Integer</tt> (ordinary digits).
Index :: Integer -> Suffix

-- | Identifier ends in number <tt>Integer</tt> (subscript digits).
Subscript :: Integer -> Suffix

-- | Increase the suffix by one.
nextSuffix :: Suffix -> Suffix

-- | Parse suffix.
suffixView :: String -> (String, Maybe Suffix)

-- | Print suffix.
renderSuffix :: Suffix -> String
addSuffix :: String -> Suffix -> String


-- | Tools for 3-way partitioning.
module Agda.Utils.Three

-- | Enum type with 3 elements.
data Three
One :: Three
Two :: Three
Three :: Three

-- | Partition a list into 3 groups.
--   
--   Preserves the relative order or elements.
partition3 :: (a -> Three) -> [a] -> ([a], [a], [a])

-- | Disjoint sum of three.
data Either3 a b c
In1 :: a -> Either3 a b c
In2 :: b -> Either3 a b c
In3 :: c -> Either3 a b c

-- | Partition a list into 3 groups.
--   
--   Preserves the relative order or elements.
partitionEithers3 :: [Either3 a b c] -> ([a], [b], [c])
mapEither3M :: Applicative m => (a -> m (Either3 b c d)) -> [a] -> m ([b], [c], [d])
forEither3M :: Applicative m => [a] -> (a -> m (Either3 b c d)) -> m ([b], [c], [d])
instance GHC.Enum.Enum Agda.Utils.Three.Three
instance GHC.Enum.Bounded Agda.Utils.Three.Three
instance GHC.Show.Show Agda.Utils.Three.Three
instance GHC.Classes.Ord Agda.Utils.Three.Three
instance GHC.Classes.Eq Agda.Utils.Three.Three
instance (GHC.Show.Show a, GHC.Show.Show b, GHC.Show.Show c) => GHC.Show.Show (Agda.Utils.Three.Either3 a b c)
instance (GHC.Classes.Ord a, GHC.Classes.Ord b, GHC.Classes.Ord c) => GHC.Classes.Ord (Agda.Utils.Three.Either3 a b c)
instance (GHC.Classes.Eq a, GHC.Classes.Eq b, GHC.Classes.Eq c) => GHC.Classes.Eq (Agda.Utils.Three.Either3 a b c)

module Agda.Utils.Tuple

-- | Bifunctoriality for pairs.
(-*-) :: (a -> c) -> (b -> d) -> (a, b) -> (c, d)
infix 2 -*-

-- | <pre>
--   mapFst f = f -*- id
--   </pre>
mapFst :: (a -> c) -> (a, b) -> (c, b)

-- | <pre>
--   mapSnd g = id -*- g
--   </pre>
mapSnd :: (b -> d) -> (a, b) -> (a, d)

-- | Lifted pairing.
(/\) :: (a -> b) -> (a -> c) -> a -> (b, c)
infix 3 /\
fst3 :: (a, b, c) -> a
snd3 :: (a, b, c) -> b
thd3 :: (a, b, c) -> c

-- | Swap the components of a pair.
swap :: (a, b) -> (b, a)
uncurry3 :: (a -> b -> c -> d) -> (a, b, c) -> d
uncurry4 :: (a -> b -> c -> d -> e) -> (a, b, c, d) -> e

-- | Monadic version of <a>-*-</a>.
mapPairM :: Applicative m => (a -> m c) -> (b -> m d) -> (a, b) -> m (c, d)

-- | Monadic <a>mapFst</a>.
mapFstM :: Functor m => (a -> m c) -> (a, b) -> m (c, b)

-- | Monadic <a>mapSnd</a>.
mapSndM :: Functor m => (b -> m d) -> (a, b) -> m (a, d)
data Pair a
Pair :: a -> a -> Pair a
instance Data.Traversable.Traversable Agda.Utils.Tuple.Pair
instance Data.Foldable.Foldable Agda.Utils.Tuple.Pair
instance GHC.Base.Functor Agda.Utils.Tuple.Pair
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Utils.Tuple.Pair a)
instance GHC.Base.Applicative Agda.Utils.Tuple.Pair


-- | Utility functions for lists.
module Agda.Utils.List

-- | Append a single element at the end. Time: O(length); use only on small
--   lists.
snoc :: [a] -> a -> [a]

-- | Case distinction for lists, with list first. O(1).
--   
--   Cf. <a>ifNull</a>.
caseList :: [a] -> b -> (a -> [a] -> b) -> b

-- | Case distinction for lists, with list first. O(1).
--   
--   Cf. <a>ifNull</a>.
caseListM :: Monad m => m [a] -> m b -> (a -> [a] -> m b) -> m b

-- | Case distinction for lists, with list last. O(1).
listCase :: b -> (a -> [a] -> b) -> [a] -> b

-- | Head function (safe). Returns a default value on empty lists. O(1).
--   
--   <pre>
--   headWithDefault 42 []      = 42
--   headWithDefault 42 [1,2,3] = 1
--   </pre>
headWithDefault :: a -> [a] -> a

-- | Tail function (safe). O(1).
tailMaybe :: [a] -> Maybe [a]

-- | Tail function (safe). Returns a default list on empty lists. O(1).
tailWithDefault :: [a] -> [a] -> [a]

-- | Last element (safe). O(n).
lastMaybe :: [a] -> Maybe a

-- | Last element (safe). Returns a default list on empty lists. O(n).
lastWithDefault :: a -> [a] -> a

-- | Last element of non-empty list (safe). O(n). <tt>last1 a as = last (a
--   : as)</tt>
last1 :: a -> [a] -> a

-- | Last two elements (safe). O(n).
last2 :: [a] -> Maybe (a, a)

-- | <tt>last2' x y zs</tt> computes the last two elements of
--   <tt>x:y:zs</tt>. O(n).
last2' :: a -> a -> [a] -> (a, a)

-- | Opposite of cons <tt>(:)</tt>, safe. O(1).
uncons :: [a] -> Maybe (a, [a])

-- | Maybe cons. O(1). <tt>mcons ma as = maybeToList ma ++ as</tt>
mcons :: Maybe a -> [a] -> [a]

-- | <a>init</a> and <a>last</a> in one go, safe. O(n).
initLast :: [a] -> Maybe ([a], a)

-- | <a>init</a> and <a>last</a> of non-empty list, safe. O(n).
--   <tt>initLast1 a as = (init (a:as), last (a:as)</tt>
initLast1 :: a -> [a] -> ([a], a)

-- | <a>init</a> of non-empty list, safe. O(n). <tt>init1 a as = init
--   (a:as)</tt>
init1 :: a -> [a] -> [a]

-- | <tt>init</tt>, safe. O(n).
initMaybe :: [a] -> Maybe [a]

-- | <tt>init</tt>, safe. O(n).
initWithDefault :: [a] -> [a] -> [a]

-- | Lookup function (safe). O(min n index).
(!!!) :: [a] -> Int -> Maybe a

-- | A variant of <a>!!</a> that might provide more informative error
--   messages if the index is out of bounds.
--   
--   Precondition: The index should not be out of bounds.
(!!) :: HasCallStack => [a] -> Int -> a

-- | Lookup function with default value for index out of range. O(min n
--   index).
--   
--   The name is chosen akin to <a>genericIndex</a>.
indexWithDefault :: a -> [a] -> Int -> a

-- | Find an element satisfying a predicate and return it with its index.
--   O(n) in the worst case, e.g. <tt>findWithIndex f xs = Nothing</tt>.
--   
--   TODO: more efficient implementation!?
findWithIndex :: (a -> Bool) -> [a] -> Maybe (a, Int)

-- | A generalised variant of <tt>elemIndex</tt>. O(n).
genericElemIndex :: (Eq a, Integral i) => a -> [a] -> Maybe i

-- | <tt>downFrom n = [n-1,..1,0]</tt>. O(n).
downFrom :: Integral a => a -> [a]

-- | Update the first element of a list, if it exists. O(1).
updateHead :: (a -> a) -> [a] -> [a]

-- | Update the last element of a list, if it exists. O(n).
updateLast :: (a -> a) -> [a] -> [a]

-- | Update nth element of a list, if it exists. <tt>O(min index n)</tt>.
--   
--   Precondition: the index is &gt;= 0.
updateAt :: Int -> (a -> a) -> [a] -> [a]
type Prefix a = -- | The list before the split point. [a]
type Suffix a = -- | The list after the split point. [a]

-- | <tt>splitExactlyAt n xs = Just (ys, zs)</tt> iff <tt>xs = ys ++
--   zs</tt> and <tt>genericLength ys = n</tt>.
splitExactlyAt :: Integral n => n -> [a] -> Maybe (Prefix a, Suffix a)

-- | Drop from the end of a list. O(length).
--   
--   <pre>
--   dropEnd n = reverse . drop n . reverse
--   </pre>
--   
--   Forces the whole list even for <tt>n==0</tt>.
dropEnd :: forall a. Int -> [a] -> Prefix a

-- | Split off the largest suffix whose elements satisfy a predicate. O(n).
--   
--   <tt>spanEnd p xs = (ys, zs)</tt> where <tt>xs = ys ++ zs</tt> and
--   <tt>all p zs</tt> and <tt>maybe True (not . p) (lastMaybe yz)</tt>.
spanEnd :: forall a. (a -> Bool) -> [a] -> (Prefix a, Suffix a)

-- | Breaks a list just <i>after</i> an element satisfying the predicate is
--   found.
--   
--   <pre>
--   &gt;&gt;&gt; breakAfter1 even 1 [3,5,2,4,7,8]
--   (1 :| [3,5,2],[4,7,8])
--   </pre>
breakAfter1 :: (a -> Bool) -> a -> [a] -> (List1 a, [a])

-- | Breaks a list just <i>after</i> an element satisfying the predicate is
--   found.
--   
--   <pre>
--   &gt;&gt;&gt; breakAfter even [1,3,5,2,4,7,8]
--   ([1,3,5,2],[4,7,8])
--   </pre>
breakAfter :: (a -> Bool) -> [a] -> ([a], [a])

-- | A generalized version of <tt>takeWhile</tt>. (Cf. <tt>mapMaybe</tt>
--   vs. <tt>filter</tt>). @O(length . takeWhileJust f).
--   
--   <tt>takeWhileJust f = fst . spanJust f</tt>.
takeWhileJust :: (a -> Maybe b) -> [a] -> Prefix b

-- | A generalized version of <tt>span</tt>. <tt>O(length . fst . spanJust
--   f)</tt>.
spanJust :: (a -> Maybe b) -> [a] -> (Prefix b, Suffix a)

-- | Partition a list into <a>Nothing</a>s and <a>Just</a>s. O(n).
--   
--   <pre>
--   partitionMaybe f = partitionEithers . map ( a -&gt; maybe (Left a) Right (f a))
--   </pre>
--   
--   Note: <tt><a>mapMaybe</a> f = snd . partitionMaybe f</tt>.
partitionMaybe :: (a -> Maybe b) -> [a] -> ([a], [b])

-- | Like <a>filter</a>, but additionally return the last partition of the
--   list where the predicate is <tt>False</tt> everywhere. O(n).
filterAndRest :: (a -> Bool) -> [a] -> ([a], Suffix a)

-- | Like <a>mapMaybe</a>, but additionally return the last partition of
--   the list where the function always returns <tt>Nothing</tt>. O(n).
mapMaybeAndRest :: (a -> Maybe b) -> [a] -> ([b], Suffix a)

-- | Sublist relation.
isSublistOf :: Eq a => [a] -> [a] -> Bool

-- | <tt>dropFrom marker xs</tt> drops everything from <tt>xs</tt> starting
--   with (and including) <tt>marker</tt>.
--   
--   If the marker does not appear, the string is returned unchanged.
--   
--   The following two properties hold provided <tt>marker</tt> has no
--   overlap with <tt>xs</tt>:
--   
--   <pre>
--   dropFrom marker (xs ++ marker ++ ys) == xs
--   dropFrom marker xs == xs
--   </pre>
dropFrom :: Eq a => List1 a -> [a] -> [a]

-- | All ways of removing one element from a list. O(n²).
holes :: [a] -> [(a, [a])]

-- | Compute the common prefix of two lists. O(min n m).
commonPrefix :: Eq a => [a] -> [a] -> Prefix a

-- | Drops from both lists simultaneously until one list is empty. O(min n
--   m).
dropCommon :: [a] -> [b] -> (Suffix a, Suffix b)

-- | Check if a list has a given prefix. If so, return the list minus the
--   prefix. O(length prefix).
stripPrefixBy :: (a -> a -> Bool) -> Prefix a -> [a] -> Maybe (Suffix a)

-- | Compute the common suffix of two lists. O(n + m).
commonSuffix :: Eq a => [a] -> [a] -> Suffix a

-- | <tt>stripSuffix suf xs = Just pre</tt> iff <tt>xs = pre ++ suf</tt>.
--   O(n).
stripSuffix :: Eq a => Suffix a -> [a] -> Maybe (Prefix a)
type ReversedSuffix a = [a]

-- | <tt>stripReversedSuffix rsuf xs = Just pre</tt> iff <tt>xs = pre ++
--   reverse suf</tt>. O(n).
stripReversedSuffix :: forall a. Eq a => ReversedSuffix a -> [a] -> Maybe (Prefix a)

-- | Internal state for stripping suffix.
data StrSufSt a

-- | Error.
SSSMismatch :: StrSufSt a

-- | "Negative string" to remove from end. List may be empty.
SSSStrip :: ReversedSuffix a -> StrSufSt a

-- | "Positive string" (result). Non-empty list.
SSSResult :: [a] -> StrSufSt a

-- | Returns a list with one boolean for each non-empty suffix of the list,
--   starting with the longest suffix (the entire list). Each boolean is
--   <a>True</a> exactly when every element in the corresponding suffix
--   satisfies the predicate.
--   
--   An example: <tt> <a>suffixesSatisfying</a> <a>isLower</a> <a>AbCde</a>
--   = [False, False, False, True, True] </tt>
--   
--   For total predicates <tt>p</tt> and finite and total lists <tt>xs</tt>
--   the following holds: <tt> <a>suffixesSatisfying</a> p xs = <a>map</a>
--   (<a>all</a> p) (<a>init</a> (<a>tails</a> xs)) </tt>
suffixesSatisfying :: (a -> Bool) -> [a] -> [Bool]

-- | Find the longest suffix of the first string <tt>xs</tt> that is a
--   prefix of the second string <tt>ys</tt>. So, basically, find the
--   overlap where the strings can be glued together. Returns the index
--   where the overlap starts and the length of the overlap. The length of
--   the overlap plus the index is the length of the first string. Note
--   that in the worst case, the empty overlap <tt>(length xs,0)</tt> is
--   returned.
--   
--   Worst-case time complexity is quadratic: <tt>O(min(n,m)²)</tt> where
--   <tt>n = length xs</tt> and <tt>m = length ys</tt>.
--   
--   There might be asymptotically better implementations following
--   Knuth-Morris-Pratt (KMP), but for rather short lists this is good
--   enough.
findOverlap :: forall a. Eq a => [a] -> [a] -> (Int, Int)

-- | Chop up a list in chunks of a given length. O(n).
chop :: Int -> [a] -> [[a]]

-- | Chop a list at the positions when the predicate holds. Contrary to
--   <tt>wordsBy</tt>, consecutive separator elements will result in an
--   empty segment in the result. O(n).
--   
--   <pre>
--   intercalate [x] (chopWhen (== x) xs) == xs
--   </pre>
chopWhen :: forall a. (a -> Bool) -> [a] -> [[a]]

-- | Check membership for the same list often. Use partially applied to
--   create membership predicate <tt>hasElem xs :: a -&gt; Bool</tt>.
--   
--   <ul>
--   <li>First time: <tt>O(n log n)</tt> in the worst case.</li>
--   <li>Subsequently: <tt>O(log n)</tt>.</li>
--   </ul>
--   
--   Specification: <tt>hasElem xs == (<a>elem</a> xs)</tt>.
hasElem :: Ord a => [a] -> a -> Bool

-- | Check whether a list is sorted. O(n).
--   
--   Assumes that the <a>Ord</a> instance implements a partial order.
sorted :: Ord a => [a] -> Bool

-- | Check whether all consecutive elements of a list satisfy the given
--   relation. O(n).
allConsecutive :: (a -> a -> Bool) -> [a] -> Bool

-- | Check whether all elements in a list are distinct from each other.
--   Assumes that the <a>Eq</a> instance stands for an equivalence
--   relation.
--   
--   O(n²) in the worst case <tt>distinct xs == True</tt>.
distinct :: Eq a => [a] -> Bool

-- | An optimised version of <a>distinct</a>. O(n log n).
--   
--   Precondition: The list's length must fit in an <a>Int</a>.
fastDistinct :: Ord a => [a] -> Bool

-- | Returns an (arbitrary) representative for each list element that
--   occurs more than once. O(n log n).
duplicates :: Ord a => [a] -> [a]

-- | Remove the first representative for each list element. Thus, returns
--   all duplicate copies. O(n log n).
--   
--   <tt>allDuplicates xs == sort $ xs \ nub xs</tt>.
allDuplicates :: Ord a => [a] -> [a]

-- | Partition a list into first and later occurrences of elements (modulo
--   some quotient given by a representation function).
--   
--   Time: O(n log n).
--   
--   Specification:
--   
--   <pre>
--   nubAndDuplicatesOn f xs = (ys, xs List.\\ ys)
--     where ys = nubOn f xs
--   </pre>
nubAndDuplicatesOn :: Ord b => (a -> b) -> [a] -> ([a], [a])

-- | Efficient variant of <tt>nubBy</tt> for lists, using a set to store
--   already seen elements. O(n log n)
--   
--   Specification:
--   
--   <pre>
--   nubOn f xs == 'nubBy' ((==) `'on'` f) xs.
--   </pre>
nubOn :: Ord b => (a -> b) -> [a] -> [a]

-- | A variant of <a>nubOn</a> that is parametrised by a function that is
--   used to select which element from a group of equal elements that is
--   returned. The returned elements keep the order that they had in the
--   input list.
--   
--   Precondition: The length of the input list must be at most
--   <tt><a>maxBound</a> :: <a>Int</a></tt>.
nubFavouriteOn :: forall a b c. (Ord b, Eq c, Hashable c) => (a -> b) -> (a -> c) -> [a] -> [a]

-- | Efficient variant of <tt>nubBy</tt> for finite lists. O(n log n).
--   
--   <pre>
--   uniqOn f == 'List.sortBy' (compare `'on'` f) . 'nubBy' ((==) `'on'` f)
--   </pre>
--   
--   If there are several elements with the same <tt>f</tt>-representative,
--   the first of these is kept.
uniqOn :: Ord b => (a -> b) -> [a] -> [a]

-- | Checks if all the elements in the list are equal. Assumes that the
--   <a>Eq</a> instance stands for an equivalence relation. O(n).
allEqual :: Eq a => [a] -> Bool

-- | Non-efficient, monadic <tt>nub</tt>. O(n²).
nubM :: Monad m => (a -> a -> m Bool) -> [a] -> m [a]

-- | Requires both lists to have the same length. O(n).
--   
--   Otherwise, <tt>Nothing</tt> is returned.
zipWith' :: (a -> b -> c) -> [a] -> [b] -> Maybe [c]

-- | Like <a>zipWith</a> but keep the rest of the second list as-is (in
--   case the second list is longer). O(n).
--   
--   <pre>
--   zipWithKeepRest f as bs == zipWith f as bs ++ drop (length as) bs
--   </pre>
zipWithKeepRest :: (a -> b -> b) -> [a] -> [b] -> [b]
unzipWith :: (a -> (b, c)) -> [a] -> ([b], [c])

-- | Implemented using tree recursion, don't run me at home! O(3^(min n
--   m)).
editDistanceSpec :: Eq a => [a] -> [a] -> Int

-- | Implemented using dynamic programming and <tt>Data.Array</tt>. O(n*m).
editDistance :: forall a. Eq a => [a] -> [a] -> Int
mergeStrictlyOrderedBy :: (a -> a -> Bool) -> [a] -> [a] -> Maybe [a]


-- | Logically consistent comparison of floating point numbers.
module Agda.Utils.Float

-- | Return Just x if it's a finite number, otherwise return Nothing.
asFinite :: Double -> Maybe Double
isPosInf :: Double -> Bool
isNegInf :: Double -> Bool
isPosZero :: Double -> Bool
isNegZero :: Double -> Bool

-- | Checks whether or not the Double is within a safe range of operation.
isSafeInteger :: Double -> Bool
doubleEq :: Double -> Double -> Bool
doubleLe :: Double -> Double -> Bool
doubleLt :: Double -> Double -> Bool
intToDouble :: Integral a => a -> Double
doublePlus :: Double -> Double -> Double
doubleMinus :: Double -> Double -> Double
doubleTimes :: Double -> Double -> Double
doubleNegate :: Double -> Double
doubleDiv :: Double -> Double -> Double
doublePow :: Double -> Double -> Double
doubleSqrt :: Double -> Double
doubleExp :: Double -> Double
doubleLog :: Double -> Double
doubleSin :: Double -> Double
doubleCos :: Double -> Double
doubleTan :: Double -> Double
doubleASin :: Double -> Double
doubleACos :: Double -> Double
doubleATan :: Double -> Double
doubleATan2 :: Double -> Double -> Double
doubleSinh :: Double -> Double
doubleCosh :: Double -> Double
doubleTanh :: Double -> Double
doubleASinh :: Double -> Double
doubleACosh :: Double -> Double
doubleATanh :: Double -> Double
doubleRound :: Double -> Maybe Integer
doubleFloor :: Double -> Maybe Integer
doubleCeiling :: Double -> Maybe Integer

-- | Denotational equality for floating point numbers, checks bitwise
--   equality.
--   
--   NOTE: Denotational equality distinguishes NaNs, so its results may
--   vary depending on the architecture and compilation flags.
--   Unfortunately, this is a problem with floating-point numbers in
--   general.
doubleDenotEq :: Double -> Double -> Bool

-- | I guess "denotational orderings" are now a thing? The point is that we
--   need an Ord instance which provides a total ordering, and is
--   consistent with the denotational equality.
--   
--   NOTE: The ordering induced via <a>doubleToWord64</a> is total, and is
--   consistent with <a>doubleDenotEq</a>. However, it is *deeply*
--   unintuitive. For one, it considers all negative numbers to be larger
--   than positive numbers.
doubleDenotOrd :: Double -> Double -> Ordering
doubleToWord64 :: Double -> Maybe Word64

-- | Decode a Double to an integer ratio.
doubleToRatio :: Double -> (Integer, Integer)

-- | Encode an integer ratio as a double.
ratioToDouble :: Integer -> Integer -> Double

-- | Decode a Double to its mantissa and its exponent, normalised such that
--   the mantissa is the smallest possible number without loss of accuracy.
doubleDecode :: Double -> Maybe (Integer, Integer)

-- | Encode a mantissa and an exponent as a Double.
doubleEncode :: Integer -> Integer -> Maybe Double

-- | Remove suffix <tt>.0</tt> from printed floating point number.
toStringWithoutDotZero :: Double -> String


-- | Additional functions for association lists.
module Agda.Utils.AssocList

-- | A finite map, represented as a set of pairs.
--   
--   Invariant: at most one value per key.
type AssocList k v = [(k, v)]

-- | O(n). Delete a binding. The key must be in the domain of the finite
--   map. Otherwise, an internal error is raised.
delete :: Eq k => k -> AssocList k v -> AssocList k v

-- | Lookup keys in the same association list often. Use partially applied
--   to create partial function <tt>apply m :: k -&gt; Maybe v</tt>.
--   
--   <ul>
--   <li>First time: <tt>O(n log n)</tt> in the worst case.</li>
--   <li>Subsequently: <tt>O(log n)</tt>.</li>
--   </ul>
--   
--   Specification: <tt>apply m == (<a>lookup</a> m)</tt>.
apply :: Ord k => AssocList k v -> k -> Maybe v

-- | O(1). Add a new binding. Assumes the binding is not yet in the list.
insert :: k -> v -> AssocList k v -> AssocList k v

-- | O(n). Map over an association list, preserving the order.
mapWithKey :: (k -> v -> v) -> AssocList k v -> AssocList k v

-- | O(n). Get the domain (list of keys) of the finite map.
keys :: AssocList k v -> [k]

-- | O(n). Update the value at a key. The key must be in the domain of the
--   finite map. Otherwise, an internal error is raised.
update :: Eq k => k -> v -> AssocList k v -> AssocList k v

-- | O(n). Update the value at a key with a certain function. The key must
--   be in the domain of the finite map. Otherwise, an internal error is
--   raised.
updateAt :: Eq k => k -> (v -> v) -> AssocList k v -> AssocList k v

-- | O(n). Named in analogy to <a>mapKeysMonotonic</a>. To preserve the
--   invariant, it is sufficient that the key transformation is injective
--   (rather than monotonic).
mapKeysMonotonic :: (k -> k') -> AssocList k v -> AssocList k' v

-- | O(n). If called with a effect-producing function, violation of the
--   invariant could matter here (duplicating effects).
mapWithKeyM :: Applicative m => (k -> v -> m v) -> AssocList k v -> m (AssocList k v)

-- | &lt;math&gt;. <a>lookup</a> <tt>key assocs</tt> looks up a key in an
--   association list. For the result to be <a>Nothing</a>, the list must
--   be finite.
--   
--   <pre>
--   &gt;&gt;&gt; lookup 2 []
--   Nothing
--   
--   &gt;&gt;&gt; lookup 2 [(1, "first")]
--   Nothing
--   
--   &gt;&gt;&gt; lookup 2 [(1, "first"), (2, "second"), (3, "third")]
--   Just "second"
--   </pre>
lookup :: Eq a => a -> [(a, b)] -> Maybe b

module Agda.Utils.TypeLevel

-- | <tt>All p as</tt> ensures that the constraint <tt>p</tt> is satisfied
--   by all the <tt>types</tt> in <tt>as</tt>. (Types is between
--   scare-quotes here because the code is actually kind polymorphic)
type family All (p :: k -> Constraint) (as :: [k]) :: Constraint

-- | On Booleans
type family If (b :: Bool) (l :: k) (r :: k) :: k

-- | On Lists
type family Foldr (c :: k -> l -> l) (n :: l) (as :: [k]) :: l

-- | Version of <tt>Foldr</tt> taking a defunctionalised argument so that
--   we can use partially applied functions.
type family Foldr' (c :: Function k (Function l l -> Type) -> Type) (n :: l) (as :: [k]) :: l
type family Map (f :: Function k l -> Type) (as :: [k]) :: [l]
data ConsMap0 :: (Function k l -> Type) -> Function k (Function [l] [l] -> Type) -> Type
data ConsMap1 :: (Function k l -> Type) -> k -> Function [l] [l] -> Type
type family Constant (b :: l) (as :: [k]) :: [l]

-- | <tt>Arrows [a1,..,an] r</tt> corresponds to <tt>a1 -&gt; .. -&gt; an
--   -&gt; r</tt> | <tt>Products [a1,..,an]</tt> corresponds to <tt>(a1,
--   (..,( an, ())..))</tt>
type Arrows (as :: [Type]) (r :: Type) = Foldr (->) r as
type Products (as :: [Type]) = Foldr (,) () as
data StrictPair a b
Pair :: a -> b -> StrictPair a b
type StrictProducts (as :: [Type]) = Foldr StrictPair () as
strictCurry :: (StrictPair a b -> c) -> a -> b -> c
strictUncurry :: (a -> b -> c) -> StrictPair a b -> c

-- | <tt>IsBase t</tt> is <tt>'True</tt> whenever <tt>t</tt> is *not* a
--   function space.
type family IsBase (t :: Type) :: Bool

-- | Using <tt>IsBase</tt> we can define notions of <tt>Domains</tt> and
--   <tt>CoDomains</tt> which *reduce* under positive information
--   <tt>IsBase t ~ 'True</tt> even though the shape of <tt>t</tt> is not
--   formally exposed
type family Domains (t :: Type) :: [Type]
type family Domains' (t :: Type) :: [Type]
type family CoDomain (t :: Type) :: Type
type family CoDomain' (t :: Type) :: Type

-- | <tt>Currying as b</tt> witnesses the isomorphism between <tt>Arrows as
--   b</tt> and <tt>Products as -&gt; b</tt>. It is defined as a type class
--   rather than by recursion on a singleton for <tt>as</tt> so all of that
--   these conversions are inlined at compile time for concrete arguments.
class Currying as b
uncurrys :: Currying as b => Proxy as -> Proxy b -> Arrows as b -> Products as -> b
currys :: Currying as b => Proxy as -> Proxy b -> (Products as -> b) -> Arrows as b
class StrictCurrying as b
strictUncurrys :: StrictCurrying as b => Proxy as -> Proxy b -> Arrows as b -> StrictProducts as -> b
strictCurrys :: StrictCurrying as b => Proxy as -> Proxy b -> (StrictProducts as -> b) -> Arrows as b
data Function :: Type -> Type -> Type
data Constant0 :: Function a (Function b a -> Type) -> Type
data Constant1 :: Type -> Function b a -> Type
type family Apply (t :: Function k l -> Type) (u :: k) :: l
instance Agda.Utils.TypeLevel.StrictCurrying '[] b
instance Agda.Utils.TypeLevel.StrictCurrying as b => Agda.Utils.TypeLevel.StrictCurrying (a : as) b
instance Agda.Utils.TypeLevel.Currying '[] b
instance Agda.Utils.TypeLevel.Currying as b => Agda.Utils.TypeLevel.Currying (a : as) b


-- | Type level literals, inspired by GHC.TypeLits.
module Agda.Utils.TypeLits

-- | Singleton for type level booleans.
data SBool (b :: Bool)
[STrue] :: SBool 'True
[SFalse] :: SBool 'False
eraseSBool :: SBool b -> Bool

-- | A known boolean is one we can obtain a singleton for. Concrete values
--   are trivially known.
class KnownBool (b :: Bool)
boolSing :: KnownBool b => SBool b
boolVal :: forall proxy b. KnownBool b => proxy b -> Bool
instance Agda.Utils.TypeLits.KnownBool 'GHC.Types.True
instance Agda.Utils.TypeLits.KnownBool 'GHC.Types.False

module Agda.Utils.Unsafe

-- | Checks if two arguments are equal as pointers in memory. Please note,
--   that this function is a hack, and it can worsen the behavior of
--   compiler. See
--   <a>https://gitlab.haskell.org/ghc/ghc/-/blob/d151546e59a50158f25c3df6728b00d3c27bb4b9/compiler/GHC/Builtin/primops.txt.pp#L3455</a>.
unsafeComparePointers :: a -> a -> Bool


-- | Overloaded <tt>null</tt> and <tt>empty</tt> for collections and
--   sequences.
module Agda.Utils.Null
class Null a
empty :: Null a => a

-- | Satisfying <tt>null empty == True</tt>.
null :: Null a => a -> Bool

-- | Satisfying <tt>null empty == True</tt>.
null :: (Null a, Eq a) => a -> Bool
ifNull :: Null a => a -> b -> (a -> b) -> b
ifNotNull :: Null a => a -> (a -> b) -> b -> b
ifNullM :: (Monad m, Null a) => m a -> m b -> (a -> m b) -> m b
ifNotNullM :: (Monad m, Null a) => m a -> (a -> m b) -> m b -> m b
whenNull :: (Monad m, Null a) => a -> m () -> m ()
unlessNull :: (Monad m, Null a) => a -> (a -> m ()) -> m ()
whenNullM :: (Monad m, Null a) => m a -> m () -> m ()
unlessNullM :: (Monad m, Null a) => m a -> (a -> m ()) -> m ()
applyUnlessNull :: Null a => a -> (a -> b -> b) -> b -> b
instance Agda.Utils.Null.Null ()
instance (Agda.Utils.Null.Null a, Agda.Utils.Null.Null b) => Agda.Utils.Null.Null (a, b)
instance (Agda.Utils.Null.Null a, Agda.Utils.Null.Null b, Agda.Utils.Null.Null c) => Agda.Utils.Null.Null (a, b, c)
instance (Agda.Utils.Null.Null a, Agda.Utils.Null.Null b, Agda.Utils.Null.Null c, Agda.Utils.Null.Null d) => Agda.Utils.Null.Null (a, b, c, d)
instance Agda.Utils.Null.Null Data.ByteString.Internal.Type.ByteString
instance Agda.Utils.Null.Null Data.ByteString.Lazy.Internal.ByteString
instance Agda.Utils.Null.Null Data.Text.Internal.Text
instance Agda.Utils.Null.Null [a]
instance Agda.Utils.Null.Null (Agda.Utils.Bag.Bag a)
instance Agda.Utils.Null.Null (Data.IntMap.Internal.IntMap a)
instance Agda.Utils.Null.Null Data.IntSet.Internal.IntSet
instance Agda.Utils.Null.Null (Data.Map.Internal.Map k a)
instance Agda.Utils.Null.Null (Data.HashMap.Internal.HashMap k a)
instance Agda.Utils.Null.Null (Data.HashSet.Internal.HashSet a)
instance Agda.Utils.Null.Null (Data.Sequence.Internal.Seq a)
instance Agda.Utils.Null.Null (Data.Set.Internal.Set a)
instance Agda.Utils.Null.Null (GHC.Maybe.Maybe a)
instance Agda.Utils.Null.Null GHC.Types.Bool
instance Agda.Utils.Null.Null (Text.PrettyPrint.Annotated.HughesPJ.Doc a)
instance Agda.Utils.Null.Null a => Agda.Utils.Null.Null (Data.Functor.Identity.Identity a)
instance Agda.Utils.Null.Null a => Agda.Utils.Null.Null (GHC.Types.IO a)
instance (Agda.Utils.Null.Null (m a), GHC.Base.Monad m) => Agda.Utils.Null.Null (Control.Monad.Trans.Except.ExceptT e m a)
instance (Agda.Utils.Null.Null (m a), GHC.Base.Monad m) => Agda.Utils.Null.Null (Control.Monad.Trans.Reader.ReaderT r m a)
instance (Agda.Utils.Null.Null (m a), GHC.Base.Monad m) => Agda.Utils.Null.Null (Control.Monad.Trans.State.Lazy.StateT s m a)
instance (Agda.Utils.Null.Null (m a), GHC.Base.Monad m, GHC.Base.Monoid w) => Agda.Utils.Null.Null (Control.Monad.Trans.Writer.Lazy.WriterT w m a)


-- | Small sets represented as a bitmask for fast membership checking.
--   
--   With the exception of converting to/from lists, all operations are
--   O(1).
--   
--   Mimics the interface of <a>Set</a>.
--   
--   Import as: <tt> import qualified Agda.Utils.SmallSet as SmallSet
--   import Agda.Utils.SmallSet (SmallSet) </tt>
module Agda.Utils.SmallSet
newtype SmallSet a
SmallSet :: Word64 -> SmallSet a
[theSmallSet] :: SmallSet a -> Word64

-- | An element in a small set.
--   
--   This must implement <a>Bounded</a> and <a>Ix</a>, and contain at most
--   64 values.
class (Bounded a, Ix a) => SmallSetElement a

-- | The <a>Ix</a> class is used to map a contiguous subrange of values in
--   a type onto integers. It is used primarily for array indexing (see the
--   array package).
--   
--   The first argument <tt>(l,u)</tt> of each of these operations is a
--   pair specifying the lower and upper bounds of a contiguous subrange of
--   values.
--   
--   An implementation is entitled to assume the following laws about these
--   operations:
--   
--   <ul>
--   <li><tt><a>inRange</a> (l,u) i == <tt>elem</tt> i (<a>range</a>
--   (l,u))</tt> <tt> </tt></li>
--   <li><tt><a>range</a> (l,u) <tt>!!</tt> <a>index</a> (l,u) i == i</tt>,
--   when <tt><a>inRange</a> (l,u) i</tt></li>
--   <li><tt><a>map</a> (<a>index</a> (l,u)) (<a>range</a> (l,u))) ==
--   [0..<a>rangeSize</a> (l,u)-1]</tt> <tt> </tt></li>
--   <li><tt><a>rangeSize</a> (l,u) == <tt>length</tt> (<a>range</a>
--   (l,u))</tt> <tt> </tt></li>
--   </ul>
class Ord a => Ix a

-- | Time O(1).
(\\) :: SmallSetElement a => SmallSet a -> SmallSet a -> SmallSet a

-- | Time O(n).
complement :: SmallSetElement a => SmallSet a -> SmallSet a

-- | Time O(1).
delete :: SmallSetElement a => a -> SmallSet a -> SmallSet a

-- | Time O(1).
difference :: SmallSetElement a => SmallSet a -> SmallSet a -> SmallSet a

-- | Time O(n).
elems :: SmallSetElement a => SmallSet a -> [a]

-- | The empty set. Time O(1).
empty :: SmallSetElement a => SmallSet a

-- | Time O(n).
fromList :: SmallSetElement a => [a] -> SmallSet a

-- | Time O(n).
fromAscList :: SmallSetElement a => [a] -> SmallSet a

-- | Time O(n).
fromDistinctAscList :: SmallSetElement a => [a] -> SmallSet a

-- | Time O(1).
insert :: SmallSetElement a => a -> SmallSet a -> SmallSet a

-- | Time O(1).
intersection :: SmallSetElement a => SmallSet a -> SmallSet a -> SmallSet a

-- | Time O(1).
member :: SmallSetElement a => a -> SmallSet a -> Bool

-- | <tt>not . member a</tt>. Time O(1).
notMember :: SmallSetElement a => a -> SmallSet a -> Bool

-- | Time O(1).
null :: SmallSetElement a => SmallSet a -> Bool

-- | A singleton set. Time O(1).
singleton :: SmallSetElement a => a -> SmallSet a

-- | Time O(n).
toList :: SmallSetElement a => SmallSet a -> [a]

-- | Time O(n).
toAscList :: SmallSetElement a => SmallSet a -> [a]

-- | The full set. Time O(1).
total :: forall a. SmallSetElement a => SmallSet a

-- | Time O(n).
union :: SmallSetElement a => SmallSet a -> SmallSet a -> SmallSet a
instance Control.DeepSeq.NFData (Agda.Utils.SmallSet.SmallSet a)
instance GHC.Show.Show (Agda.Utils.SmallSet.SmallSet a)
instance GHC.Classes.Ord (Agda.Utils.SmallSet.SmallSet a)
instance GHC.Classes.Eq (Agda.Utils.SmallSet.SmallSet a)
instance Agda.Utils.SmallSet.SmallSetElement a => Agda.Utils.Null.Null (Agda.Utils.SmallSet.SmallSet a)
instance Agda.Utils.SmallSet.SmallSetElement a => GHC.Base.Semigroup (Agda.Utils.SmallSet.SmallSet a)
instance Agda.Utils.SmallSet.SmallSetElement a => GHC.Base.Monoid (Agda.Utils.SmallSet.SmallSet a)


-- | Constructing singleton collections.
module Agda.Utils.Singleton

-- | A create-only possibly empty collection is a monoid with the
--   possibility to inject elements.
class (Semigroup coll, Monoid coll, Singleton el coll) => Collection el coll | coll -> el
fromList :: Collection el coll => [el] -> coll

-- | Create-only collection with at most one element.
class (Null coll, Singleton el coll) => CMaybe el coll | coll -> el
cMaybe :: CMaybe el coll => Maybe el -> coll

-- | Overloaded <tt>singleton</tt> constructor for collections.
class Singleton el coll | coll -> el
singleton :: Singleton el coll => el -> coll
instance Agda.Utils.Singleton.Collection a [a]
instance Agda.Utils.Singleton.Collection a ([a] -> [a])
instance Agda.Utils.Singleton.Collection a (Data.Semigroup.Internal.Endo [a])
instance Agda.Utils.Singleton.Collection a (Data.DList.Internal.DList a)
instance Agda.Utils.Singleton.Collection a (Data.Sequence.Internal.Seq a)
instance Agda.Utils.Singleton.Collection GHC.Types.Int Data.IntSet.Internal.IntSet
instance Agda.Utils.Singleton.Collection (GHC.Types.Int, a) (Data.IntMap.Internal.IntMap a)
instance GHC.Classes.Ord a => Agda.Utils.Singleton.Collection a (Data.Set.Internal.Set a)
instance GHC.Classes.Ord k => Agda.Utils.Singleton.Collection (k, a) (Data.Map.Internal.Map k a)
instance (GHC.Classes.Eq a, Data.Hashable.Class.Hashable a) => Agda.Utils.Singleton.Collection a (Data.HashSet.Internal.HashSet a)
instance (GHC.Classes.Eq k, Data.Hashable.Class.Hashable k) => Agda.Utils.Singleton.Collection (k, a) (Data.HashMap.Internal.HashMap k a)
instance Agda.Utils.SmallSet.SmallSetElement a => Agda.Utils.Singleton.Collection a (Agda.Utils.SmallSet.SmallSet a)
instance Agda.Utils.Singleton.CMaybe a (GHC.Maybe.Maybe a)
instance Agda.Utils.Singleton.CMaybe a [a]
instance Agda.Utils.Singleton.Singleton a (GHC.Maybe.Maybe a)
instance Agda.Utils.Singleton.Singleton a [a]
instance Agda.Utils.Singleton.Singleton a ([a] -> [a])
instance Agda.Utils.Singleton.Singleton a (Data.Semigroup.Internal.Endo [a])
instance Agda.Utils.Singleton.Singleton a (Data.DList.Internal.DList a)
instance Agda.Utils.Singleton.Singleton a (GHC.Base.NonEmpty a)
instance Agda.Utils.Singleton.Singleton a (Data.Sequence.Internal.Seq a)
instance Agda.Utils.Singleton.Singleton a (Data.Set.Internal.Set a)
instance Agda.Utils.Singleton.Singleton GHC.Types.Int Data.IntSet.Internal.IntSet
instance Agda.Utils.SmallSet.SmallSetElement a => Agda.Utils.Singleton.Singleton a (Agda.Utils.SmallSet.SmallSet a)
instance Agda.Utils.Singleton.Singleton (k, a) (Data.Map.Internal.Map k a)
instance Agda.Utils.Singleton.Singleton (GHC.Types.Int, a) (Data.IntMap.Internal.IntMap a)
instance Data.Hashable.Class.Hashable a => Agda.Utils.Singleton.Singleton a (Data.HashSet.Internal.HashSet a)
instance Data.Hashable.Class.Hashable k => Agda.Utils.Singleton.Singleton (k, a) (Data.HashMap.Internal.HashMap k a)


-- | Create clusters of non-overlapping things.
module Agda.Utils.Cluster

-- | Given a function <tt>f :: a -&gt; NonEmpty c</tt> which returns a
--   non-empty list of characteristics of <tt>a</tt>, partition a list of
--   <tt>a</tt>s into groups such that each element in a group shares at
--   least one characteristic with at least one other element of the group.
cluster :: Ord c => (a -> NonEmpty c) -> [a] -> [NonEmpty a]

-- | Partition a list of <tt>a</tt>s paired with a non-empty list of
--   characteristics into groups such that each element in a group shares
--   at least one characteristic with at least one other element of the
--   group.
cluster' :: Ord c => [(a, NonEmpty c)] -> [NonEmpty a]

-- | Given a function <tt>f :: a -&gt; NonEmpty c</tt> which returns a
--   non-empty list of characteristics of <tt>a</tt>, partition a non-empty
--   list of <tt>a</tt>s into groups such that each element in a group
--   shares at least one characteristic with at least one other element of
--   the group.
cluster1 :: Ord c => (a -> NonEmpty c) -> NonEmpty a -> NonEmpty (NonEmpty a)

-- | Partition a non-empty list of <tt>a</tt>s paired with a non-empty list
--   of characteristics into groups such that each element in a group
--   shares at least one characteristic with at least one other element of
--   the group.
cluster1' :: Ord c => NonEmpty (a, NonEmpty c) -> NonEmpty (NonEmpty a)


-- | A strict version of the <a>Maybe</a> type.
--   
--   Import qualified, as in <tt> import qualified Agda.Utils.Maybe.Strict
--   as Strict </tt>
module Agda.Utils.Maybe.Strict

-- | Version of <a>mapMaybe</a> with different argument ordering.
forMaybe :: [a] -> (a -> Maybe b) -> [b]

-- | Monadic version of <a>caseMaybe</a>. That is, <a>maybeM</a> with a
--   different argument ordering.
caseMaybeM :: Monad m => m (Maybe a) -> m b -> (a -> m b) -> m b

-- | Monadic version of <a>fromMaybe</a>.
fromMaybeM :: Monad m => m a -> m (Maybe a) -> m a

-- | Filtering a singleton list.
--   
--   <pre>
--   filterMaybe p a = <a>listToMaybe</a> (<a>filter</a> p [a])
--   </pre>
filterMaybe :: (a -> Bool) -> a -> Maybe a

-- | A more telling name for <a>forM</a> for the <a>Maybe</a> collection
--   type. Or: <a>caseMaybe</a> without the <a>Nothing</a> case.
whenJust :: Monad m => Maybe a -> (a -> m ()) -> m ()

-- | <tt>unionWith</tt> for collections of size &lt;= 1.
unionMaybeWith :: (a -> a -> a) -> Maybe a -> Maybe a -> Maybe a

-- | Unzipping a list of length &lt;= 1.
unzipMaybe :: Maybe (a, b) -> (Maybe a, Maybe b)

-- | Version of <a>maybe</a> with different argument ordering. Often, we
--   want to case on a <a>Maybe</a>, do something interesting in the
--   <a>Just</a> case, but only a default action in the <a>Nothing</a>
--   case. Then, the argument ordering of <tt>caseMaybe</tt> is preferable.
--   
--   <pre>
--   caseMaybe m err f = flip (maybe err) m f
--   </pre>
caseMaybe :: Maybe a -> b -> (a -> b) -> b

-- | Monadic version of <a>maybe</a>.
maybeM :: Monad m => m b -> (a -> m b) -> m (Maybe a) -> m b

-- | <a>caseMaybeM</a> with flipped branches.
ifJustM :: Monad m => m (Maybe a) -> (a -> m b) -> m b -> m b

-- | <a>caseMaybeM</a> without the <a>Nothing</a> case.
whenJustM :: Monad m => m (Maybe a) -> (a -> m ()) -> m ()
instance GHC.Base.Applicative Data.Strict.Maybe.Maybe
instance Agda.Utils.Null.Null (Data.Strict.Maybe.Maybe a)


-- | Strict tries (based on <a>Data.Map.Strict</a> and
--   <a>Agda.Utils.Maybe.Strict</a>).
module Agda.Utils.Trie

-- | Finite map from <tt>[k]</tt> to <tt>v</tt>.
--   
--   With the strict <a>Maybe</a> type, <a>Trie</a> is also strict in
--   <tt>v</tt>.
data Trie k v
Trie :: !Maybe v -> !Map k (Trie k v) -> Trie k v
empty :: Null a => a

-- | Singleton trie.
singleton :: [k] -> v -> Trie k v

-- | <tt>everyPrefix k v</tt> is a trie where every prefix of <tt>k</tt>
--   (including <tt>k</tt> itself) is mapped to <tt>v</tt>.
everyPrefix :: [k] -> v -> Trie k v

-- | Insert. Overwrites existing value if present.
--   
--   <pre>
--   insert = insertWith ( new old -&gt; new)
--   </pre>
insert :: Ord k => [k] -> v -> Trie k v -> Trie k v

-- | Insert with function merging new value with old value.
insertWith :: Ord k => (v -> v -> v) -> [k] -> v -> Trie k v -> Trie k v

-- | Left biased union.
--   
--   <tt>union = unionWith ( new old -&gt; new)</tt>.
union :: Ord k => Trie k v -> Trie k v -> Trie k v

-- | Pointwise union with merge function for values.
unionWith :: Ord k => (v -> v -> v) -> Trie k v -> Trie k v -> Trie k v

-- | Adjust value at key, leave subtree intact.
adjust :: Ord k => [k] -> (Maybe v -> Maybe v) -> Trie k v -> Trie k v

-- | Delete value at key, but leave subtree intact.
delete :: Ord k => [k] -> Trie k v -> Trie k v

-- | Convert to ascending list.
toList :: Ord k => Trie k v -> [([k], v)]

-- | Convert to ascending list.
toAscList :: Ord k => Trie k v -> [([k], v)]

-- | Convert to list where nodes at the same level are ordered according to
--   the given ordering.
toListOrderedBy :: Ord k => (v -> v -> Ordering) -> Trie k v -> [([k], v)]

-- | Returns the value associated with the given key, if any.
lookup :: Ord k => [k] -> Trie k v -> Maybe v

-- | Is the given key present in the trie?
member :: Ord k => [k] -> Trie k v -> Bool

-- | Collect all values along a given path.
lookupPath :: Ord k => [k] -> Trie k v -> [v]

-- | Get the subtrie rooted at the given key.
lookupTrie :: Ord k => [k] -> Trie k v -> Trie k v

-- | Create new values based on the entire subtrie. Almost, but not quite
--   comonad extend.
mapSubTries :: Ord k => (Trie k u -> Maybe v) -> Trie k u -> Trie k v

-- | Filter a trie.
filter :: Ord k => (v -> Bool) -> Trie k v -> Trie k v

-- | Key lens.
valueAt :: Ord k => [k] -> Lens' (Trie k v) (Maybe v)
instance Data.Foldable.Foldable (Agda.Utils.Trie.Trie k)
instance GHC.Base.Functor (Agda.Utils.Trie.Trie k)
instance (GHC.Classes.Eq v, GHC.Classes.Eq k) => GHC.Classes.Eq (Agda.Utils.Trie.Trie k v)
instance (GHC.Show.Show v, GHC.Show.Show k) => GHC.Show.Show (Agda.Utils.Trie.Trie k v)
instance (Control.DeepSeq.NFData k, Control.DeepSeq.NFData v) => Control.DeepSeq.NFData (Agda.Utils.Trie.Trie k v)
instance Agda.Utils.Null.Null (Agda.Utils.Trie.Trie k v)


-- | Non-empty lists.
--   
--   Better name <tt>List1</tt> for non-empty lists, plus missing
--   functionality.
--   
--   Import: @
--   
--   {-# LANGUAGE PatternSynonyms #-}
--   
--   import Agda.Utils.List1 (List1, pattern (:|)) import qualified
--   Agda.Utils.List1 as List1
--   
--   @
module Agda.Utils.List1
type List1 = NonEmpty
type String1 = List1 Char

-- | List <a>foldr</a> but with a base case for the singleton list.
foldr :: (a -> b -> b) -> (a -> b) -> List1 a -> b

-- | Like <a>union</a>. Duplicates in the first list are not removed.
--   O(nm).
union :: Eq a => List1 a -> List1 a -> List1 a

-- | Like <a>mapMaybe</a>.
mapMaybe :: (a -> Maybe b) -> List1 a -> [b]

-- | Like <a>catMaybes</a>.
catMaybes :: List1 (Maybe a) -> [a]

-- | Concatenate one or more non-empty lists.
concat :: [List1 a] -> [a]

-- | Like <a>lefts</a>.
lefts :: List1 (Either a b) -> [a]

-- | Like <a>rights</a>.
rights :: List1 (Either a b) -> [b]

-- | Like <a>partitionEithers</a>.
partitionEithers :: List1 (Either a b) -> ([a], [b])

-- | Like <a>find</a>.
find :: (a -> Bool) -> List1 a -> Maybe a

-- | Like <a>unwords</a>.
unwords :: List1 String -> String

-- | Like <a>zipWithM</a>.
zipWithM :: Applicative m => (a -> b -> m c) -> List1 a -> List1 b -> m (List1 c)

-- | Like <a>zipWithM</a>.
zipWithM_ :: Applicative m => (a -> b -> m c) -> List1 a -> List1 b -> m ()

-- | Build a list with one element.
--   
--   More precise type for <tt>snoc</tt>.
snoc :: [a] -> a -> List1 a

-- | Split a list into sublists. Generalisation of the prelude function
--   <tt>words</tt>. Same as <a>wordsBy</a> and <a>wordsBy</a>, but with
--   the non-emptyness guarantee on the chunks. O(n).
--   
--   <pre>
--   words xs == wordsBy isSpace xs
--   </pre>
wordsBy :: (a -> Bool) -> [a] -> [List1 a]
ifNull :: [a] -> b -> (List1 a -> b) -> b

-- | Return the last element and the rest.
initLast :: List1 a -> ([a], a)

-- | Update the first element of a non-empty list. O(1).
updateHead :: (a -> a) -> List1 a -> List1 a

-- | Update the last element of a non-empty list. O(n).
updateLast :: (a -> a) -> List1 a -> List1 a

-- | Last two elements (safe). O(n).
last2 :: List1 a -> Maybe (a, a)
ifNotNull :: [a] -> (List1 a -> b) -> b -> b
unlessNull :: Null m => [a] -> (List1 a -> m) -> m

-- | Lift a function on non-empty lists to a function on lists.
--   
--   This is in essence <a>fmap</a> for <a>Maybe</a>, if we take <tt>[a] =
--   Maybe (List1 a)</tt>.
liftList1 :: (List1 a -> List1 b) -> [a] -> [b]

-- | Breaks a list just <i>after</i> an element satisfying the predicate is
--   found.
--   
--   <pre>
--   &gt;&gt;&gt; breakAfter even [1,3,5,2,4,7,8]
--   (1 :| [3,5,2],[4,7,8])
--   </pre>
breakAfter :: (a -> Bool) -> List1 a -> (List1 a, [a])

-- | Checks if all the elements in the list are equal. Assumes that the
--   <a>Eq</a> instance stands for an equivalence relation. O(n).
allEqual :: Eq a => List1 a -> Bool

-- | Non-efficient, monadic <a>nub</a>. O(n²).
nubM :: Monad m => (a -> a -> m Bool) -> List1 a -> m (List1 a)

-- | Lossless <a>toList</a>, opposite of <a>nonEmpty</a>.
toList' :: Maybe (List1 a) -> [a]

-- | Safe version of <a>fromList</a>.
fromListSafe :: List1 a -> [a] -> List1 a

-- | <tt><a>groupOn</a> f = <a>groupBy</a> ((<a>==</a>) `on` f) <a>.</a>
--   <a>sortBy</a> (<a>compare</a> `on` f)</tt>. O(n log n).
groupOn :: Ord b => (a -> b) -> [a] -> [List1 a]
groupOn1 :: Ord b => (a -> b) -> List1 a -> List1 (List1 a)

-- | More precise type for <a>groupBy'</a>.
--   
--   A variant of <a>groupBy</a> which applies the predicate to consecutive
--   pairs. O(n).
groupBy' :: forall a. (a -> a -> Bool) -> [a] -> [List1 a]

-- | Group consecutive items that share the same first component.
groupByFst :: forall a b. Eq a => [(a, b)] -> [(a, List1 b)]

-- | Group consecutive items that share the same first component.
groupByFst1 :: forall a b. Eq a => List1 (a, b) -> List1 (a, List1 b)
concatMap1 :: (a -> List1 b) -> List1 a -> List1 b

-- | Focus on the first element of a non-empty list. O(1).
lensHead :: Functor f => (a -> f a) -> List1 a -> f (List1 a)

-- | Focus on the last element of a non-empty list. O(n).
lensLast :: Functor f => (a -> f a) -> List1 a -> f (List1 a)

-- | Non-empty (and non-strict) list type.
data () => NonEmpty a
(:|) :: a -> [a] -> NonEmpty a
infixr 5 :|

-- | Sort a stream.
sort :: Ord a => NonEmpty a -> NonEmpty a

-- | Map a function over a <a>NonEmpty</a> stream.
map :: (a -> b) -> NonEmpty a -> NonEmpty b

-- | Construct a <a>NonEmpty</a> list from a single element.
singleton :: a -> NonEmpty a

-- | <tt><a>insert</a> x xs</tt> inserts <tt>x</tt> into the last position
--   in <tt>xs</tt> where it is still less than or equal to the next
--   element. In particular, if the list is sorted beforehand, the result
--   will also be sorted.
insert :: (Foldable f, Ord a) => a -> f a -> NonEmpty a

-- | <tt><a>filter</a> p xs</tt> removes any elements from <tt>xs</tt> that
--   do not satisfy <tt>p</tt>.
filter :: (a -> Bool) -> NonEmpty a -> [a]

-- | The <a>zipWith</a> function generalizes <a>zip</a>. Rather than
--   tupling the elements, the elements are combined using the function
--   passed as the first argument.
zipWith :: (a -> b -> c) -> NonEmpty a -> NonEmpty b -> NonEmpty c

-- | <a>sortBy</a> for <a>NonEmpty</a>, behaves the same as <a>sortBy</a>
sortBy :: (a -> a -> Ordering) -> NonEmpty a -> NonEmpty a

-- | Number of elements in <a>NonEmpty</a> list.
length :: NonEmpty a -> Int

-- | Extract the first element of the stream.
head :: NonEmpty a -> a

-- | The <a>group</a> function takes a stream and returns a list of streams
--   such that flattening the resulting list is equal to the argument.
--   Moreover, each stream in the resulting list contains only equal
--   elements. For example, in list notation:
--   
--   <pre>
--   'group' $ 'cycle' "Mississippi"
--     = "M" : "i" : "ss" : "i" : "ss" : "i" : "pp" : "i" : "M" : "i" : ...
--   </pre>
group :: (Foldable f, Eq a) => f a -> [NonEmpty a]

-- | <a>groupBy</a> operates like <a>group</a>, but uses the provided
--   equality predicate instead of <a>==</a>.
groupBy :: Foldable f => (a -> a -> Bool) -> f a -> [NonEmpty a]

-- | The <a>unfoldr</a> function is analogous to <a>Data.List</a>'s
--   <a>unfoldr</a> operation.
unfoldr :: (a -> (b, Maybe a)) -> a -> NonEmpty b

-- | <a>transpose</a> for <a>NonEmpty</a>, behaves the same as
--   <a>transpose</a> The rows/columns need not be the same length, in
--   which case &gt; transpose . transpose /= id
transpose :: NonEmpty (NonEmpty a) -> NonEmpty (NonEmpty a)

-- | <tt><a>cycle</a> xs</tt> returns the infinite repetition of
--   <tt>xs</tt>:
--   
--   <pre>
--   cycle (1 :| [2,3]) = 1 :| [2,3,1,2,3,...]
--   </pre>
cycle :: NonEmpty a -> NonEmpty a

-- | The <a>zip</a> function takes two streams and returns a stream of
--   corresponding pairs.
zip :: NonEmpty a -> NonEmpty b -> NonEmpty (a, b)

-- | <a>uncons</a> produces the first element of the stream, and a stream
--   of the remaining elements, if any.
uncons :: NonEmpty a -> (a, Maybe (NonEmpty a))

-- | Extract the possibly-empty tail of the stream.
tail :: NonEmpty a -> [a]

-- | Extract the last element of the stream.
last :: NonEmpty a -> a

-- | Extract everything except the last element of the stream.
init :: NonEmpty a -> [a]

-- | <a>scanl</a> is similar to <a>foldl</a>, but returns a stream of
--   successive reduced values from the left:
--   
--   <pre>
--   scanl f z [x1, x2, ...] == z :| [z `f` x1, (z `f` x1) `f` x2, ...]
--   </pre>
--   
--   Note that
--   
--   <pre>
--   last (scanl f z xs) == foldl f z xs.
--   </pre>
scanl :: Foldable f => (b -> a -> b) -> b -> f a -> NonEmpty b

-- | <a>scanl1</a> is a variant of <a>scanl</a> that has no starting value
--   argument:
--   
--   <pre>
--   scanl1 f [x1, x2, ...] == x1 :| [x1 `f` x2, x1 `f` (x2 `f` x3), ...]
--   </pre>
scanl1 :: (a -> a -> a) -> NonEmpty a -> NonEmpty a

-- | <a>scanr</a> is the right-to-left dual of <a>scanl</a>. Note that
--   
--   <pre>
--   head (scanr f z xs) == foldr f z xs.
--   </pre>
scanr :: Foldable f => (a -> b -> b) -> b -> f a -> NonEmpty b

-- | <a>scanr1</a> is a variant of <a>scanr</a> that has no starting value
--   argument.
scanr1 :: (a -> a -> a) -> NonEmpty a -> NonEmpty a

-- | <tt><a>iterate</a> f x</tt> produces the infinite sequence of repeated
--   applications of <tt>f</tt> to <tt>x</tt>.
--   
--   <pre>
--   iterate f x = x :| [f x, f (f x), ..]
--   </pre>
iterate :: (a -> a) -> a -> NonEmpty a

-- | <tt><a>repeat</a> x</tt> returns a constant stream, where all elements
--   are equal to <tt>x</tt>.
repeat :: a -> NonEmpty a

-- | <tt><a>takeWhile</a> p xs</tt> returns the longest prefix of the
--   stream <tt>xs</tt> for which the predicate <tt>p</tt> holds.
takeWhile :: (a -> Bool) -> NonEmpty a -> [a]

-- | <tt><a>dropWhile</a> p xs</tt> returns the suffix remaining after
--   <tt><a>takeWhile</a> p xs</tt>.
dropWhile :: (a -> Bool) -> NonEmpty a -> [a]

-- | <tt><a>take</a> n xs</tt> returns the first <tt>n</tt> elements of
--   <tt>xs</tt>.
take :: Int -> NonEmpty a -> [a]

-- | <tt><a>drop</a> n xs</tt> drops the first <tt>n</tt> elements off the
--   front of the sequence <tt>xs</tt>.
drop :: Int -> NonEmpty a -> [a]

-- | <tt><a>splitAt</a> n xs</tt> returns a pair consisting of the prefix
--   of <tt>xs</tt> of length <tt>n</tt> and the remaining stream
--   immediately following this prefix.
--   
--   <pre>
--   'splitAt' n xs == ('take' n xs, 'drop' n xs)
--   xs == ys ++ zs where (ys, zs) = 'splitAt' n xs
--   </pre>
splitAt :: Int -> NonEmpty a -> ([a], [a])

-- | <tt><a>span</a> p xs</tt> returns the longest prefix of <tt>xs</tt>
--   that satisfies <tt>p</tt>, together with the remainder of the stream.
--   
--   <pre>
--   'span' p xs == ('takeWhile' p xs, 'dropWhile' p xs)
--   xs == ys ++ zs where (ys, zs) = 'span' p xs
--   </pre>
span :: (a -> Bool) -> NonEmpty a -> ([a], [a])

-- | The <tt><a>break</a> p</tt> function is equivalent to <tt><a>span</a>
--   (not . p)</tt>.
break :: (a -> Bool) -> NonEmpty a -> ([a], [a])

-- | <a>reverse</a> a finite NonEmpty stream.
reverse :: NonEmpty a -> NonEmpty a

-- | <tt>xs !! n</tt> returns the element of the stream <tt>xs</tt> at
--   index <tt>n</tt>. Note that the head of the stream has index 0.
--   
--   <i>Beware</i>: a negative or out-of-bounds index will cause an error.
(!!) :: HasCallStack => NonEmpty a -> Int -> a
infixl 9 !!

-- | Compute n-ary logic exclusive OR operation on <a>NonEmpty</a> list.
xor :: NonEmpty Bool -> Bool

-- | The <a>isPrefixOf</a> function returns <a>True</a> if the first
--   argument is a prefix of the second.
isPrefixOf :: Eq a => [a] -> NonEmpty a -> Bool

-- | The <a>nub</a> function removes duplicate elements from a list. In
--   particular, it keeps only the first occurrence of each element. (The
--   name <a>nub</a> means 'essence'.) It is a special case of
--   <a>nubBy</a>, which allows the programmer to supply their own
--   inequality test.
nub :: Eq a => NonEmpty a -> NonEmpty a

-- | The <a>nubBy</a> function behaves just like <a>nub</a>, except it uses
--   a user-supplied equality predicate instead of the overloaded <a>==</a>
--   function.
nubBy :: (a -> a -> Bool) -> NonEmpty a -> NonEmpty a

-- | 'intersperse x xs' alternates elements of the list with copies of
--   <tt>x</tt>.
--   
--   <pre>
--   intersperse 0 (1 :| [2,3]) == 1 :| [0,2,0,3]
--   </pre>
intersperse :: a -> NonEmpty a -> NonEmpty a

-- | The <a>partition</a> function takes a predicate <tt>p</tt> and a
--   stream <tt>xs</tt>, and returns a pair of lists. The first list
--   corresponds to the elements of <tt>xs</tt> for which <tt>p</tt> holds;
--   the second corresponds to the elements of <tt>xs</tt> for which
--   <tt>p</tt> does not hold.
--   
--   <pre>
--   'partition' p xs = ('filter' p xs, 'filter' (not . p) xs)
--   </pre>
partition :: (a -> Bool) -> NonEmpty a -> ([a], [a])

-- | The <a>inits</a> function takes a stream <tt>xs</tt> and returns all
--   the finite prefixes of <tt>xs</tt>, starting with the shortest. The
--   result is <a>NonEmpty</a> because the result always contains the empty
--   list as the first element.
--   
--   <pre>
--   inits [1,2,3] == [] :| [[1], [1,2], [1,2,3]]
--   inits [1] == [] :| [[1]]
--   inits [] == [] :| []
--   </pre>
inits :: Foldable f => f a -> NonEmpty [a]

-- | The <a>tails</a> function takes a stream <tt>xs</tt> and returns all
--   the suffixes of <tt>xs</tt>, starting with the longest. The result is
--   <a>NonEmpty</a> because the result always contains the empty list as
--   the last element.
--   
--   <pre>
--   tails [1,2,3] == [1,2,3] :| [[2,3], [3], []]
--   tails [1] == [1] :| [[]]
--   tails [] == [] :| []
--   </pre>
tails :: Foldable f => f a -> NonEmpty [a]

-- | <a>unfold</a> produces a new stream by repeatedly applying the
--   unfolding function to the seed value to produce an element of type
--   <tt>b</tt> and a new seed value. When the unfolding function returns
--   <a>Nothing</a> instead of a new seed value, the stream ends.
unfold :: (a -> (b, Maybe a)) -> a -> NonEmpty b

-- | <a>nonEmpty</a> efficiently turns a normal list into a <a>NonEmpty</a>
--   stream, producing <a>Nothing</a> if the input is empty.
nonEmpty :: [a] -> Maybe (NonEmpty a)

-- | Prepend an element to the stream.
(<|) :: a -> NonEmpty a -> NonEmpty a
infixr 5 <|

-- | Synonym for <a>&lt;|</a>.
cons :: a -> NonEmpty a -> NonEmpty a

-- | The <a>inits1</a> function takes a <a>NonEmpty</a> stream <tt>xs</tt>
--   and returns all the <a>NonEmpty</a> finite prefixes of <tt>xs</tt>,
--   starting with the shortest.
--   
--   <pre>
--   inits1 (1 :| [2,3]) == (1 :| []) :| [1 :| [2], 1 :| [2,3]]
--   inits1 (1 :| []) == (1 :| []) :| []
--   </pre>
inits1 :: NonEmpty a -> NonEmpty (NonEmpty a)

-- | The <a>tails1</a> function takes a <a>NonEmpty</a> stream <tt>xs</tt>
--   and returns all the non-empty suffixes of <tt>xs</tt>, starting with
--   the longest.
--   
--   <pre>
--   tails1 (1 :| [2,3]) == (1 :| [2,3]) :| [2 :| [3], 3 :| []]
--   tails1 (1 :| []) == (1 :| []) :| []
--   </pre>
tails1 :: NonEmpty a -> NonEmpty (NonEmpty a)

-- | <tt><a>some1</a> x</tt> sequences <tt>x</tt> one or more times.
some1 :: Alternative f => f a -> f (NonEmpty a)

-- | <a>groupWith</a> operates like <a>group</a>, but uses the provided
--   projection when comparing for equality
groupWith :: (Foldable f, Eq b) => (a -> b) -> f a -> [NonEmpty a]

-- | <a>groupAllWith</a> operates like <a>groupWith</a>, but sorts the list
--   first so that each equivalence class has, at most, one list in the
--   output
groupAllWith :: Ord b => (a -> b) -> [a] -> [NonEmpty a]

-- | <a>group1</a> operates like <a>group</a>, but uses the knowledge that
--   its input is non-empty to produce guaranteed non-empty output.
group1 :: Eq a => NonEmpty a -> NonEmpty (NonEmpty a)

-- | <a>groupBy1</a> is to <a>group1</a> as <a>groupBy</a> is to
--   <a>group</a>.
groupBy1 :: (a -> a -> Bool) -> NonEmpty a -> NonEmpty (NonEmpty a)

-- | <a>groupWith1</a> is to <a>group1</a> as <a>groupWith</a> is to
--   <a>group</a>
groupWith1 :: Eq b => (a -> b) -> NonEmpty a -> NonEmpty (NonEmpty a)

-- | <a>groupAllWith1</a> is to <a>groupWith1</a> as <a>groupAllWith</a> is
--   to <a>groupWith</a>
groupAllWith1 :: Ord b => (a -> b) -> NonEmpty a -> NonEmpty (NonEmpty a)

-- | <a>sortWith</a> for <a>NonEmpty</a>, behaves the same as:
--   
--   <pre>
--   sortBy . comparing
--   </pre>
sortWith :: Ord o => (a -> o) -> NonEmpty a -> NonEmpty a

-- | A monomorphic version of <a>&lt;&gt;</a> for <a>NonEmpty</a>.
--   
--   <pre>
--   &gt;&gt;&gt; append (1 :| []) (2 :| [3])
--   1 :| [2,3]
--   </pre>
append :: NonEmpty a -> NonEmpty a -> NonEmpty a

-- | Attach a list at the end of a <a>NonEmpty</a>.
--   
--   <pre>
--   &gt;&gt;&gt; appendList (1 :| [2,3]) []
--   1 :| [2,3]
--   </pre>
--   
--   <pre>
--   &gt;&gt;&gt; appendList (1 :| [2,3]) [4,5]
--   1 :| [2,3,4,5]
--   </pre>
appendList :: NonEmpty a -> [a] -> NonEmpty a

-- | Attach a list at the beginning of a <a>NonEmpty</a>.
--   
--   <pre>
--   &gt;&gt;&gt; prependList [] (1 :| [2,3])
--   1 :| [2,3]
--   </pre>
--   
--   <pre>
--   &gt;&gt;&gt; prependList [negate 1, 0] (1 :| [2, 3])
--   -1 :| [0,1,2,3]
--   </pre>
prependList :: [a] -> NonEmpty a -> NonEmpty a

-- | The <a>IsList</a> class and its methods are intended to be used in
--   conjunction with the OverloadedLists extension.
class () => IsList l where {
    
    -- | The <a>Item</a> type function returns the type of items of the
    --   structure <tt>l</tt>.
    type family Item l;
}

-- | The <a>fromList</a> function constructs the structure <tt>l</tt> from
--   the given list of <tt>Item l</tt>
fromList :: IsList l => [Item l] -> l

-- | The <a>fromListN</a> function takes the input list's length and
--   potentially uses it to construct the structure <tt>l</tt> more
--   efficiently compared to <a>fromList</a>. If the given number does not
--   equal to the input list's length the behaviour of <a>fromListN</a> is
--   not specified.
--   
--   <pre>
--   fromListN (length xs) xs == fromList xs
--   </pre>
fromListN :: IsList l => Int -> [Item l] -> l

-- | The <a>toList</a> function extracts a list of <tt>Item l</tt> from the
--   structure <tt>l</tt>. It should satisfy fromList . toList = id.
toList :: IsList l => l -> [Item l]

-- | The <a>Item</a> type function returns the type of items of the
--   structure <tt>l</tt>.
type family Item l

-- | The <a>unzip</a> function is the inverse of the <a>zip</a> function.
unzip :: Functor f => f (a, b) -> (f a, f b)

module Agda.Utils.String

-- | <a>quote</a> adds double quotes around the string, replaces newline
--   characters with <tt>n</tt>, and escapes double quotes and backslashes
--   within the string. This is different from the behaviour of
--   <a>show</a>:
--   
--   <pre>
--   &gt; <a>putStrLn</a> $ <a>show</a> "\x2200"
--   "\8704"
--   &gt; <a>putStrLn</a> $ <a>quote</a> "\x2200"
--   "∀"
--   </pre>
--   
--   (The code examples above have been tested using version 4.2.0.0 of the
--   base library.)
quote :: String -> String

-- | Turns the string into a Haskell string literal, avoiding escape codes.
haskellStringLiteral :: String -> String

-- | Adds hyphens around the given string
--   
--   <pre>
--   &gt;&gt;&gt; putStrLn $ delimiter "Title"
--   ———— Title —————————————————————————————————————————————————
--   </pre>
delimiter :: String -> String

-- | Adds a final newline if there is not already one.
addFinalNewLine :: String -> String

-- | Indents every line the given number of steps.
indent :: Integral i => i -> String -> String

-- | <a>unwords</a>, but remove empty words first.
unwords1 :: [String] -> String

-- | Show a number using comma to separate powers of 1,000.
showThousandSep :: Show a => a -> String

-- | Remove leading whitespace.
ltrim :: String -> String

-- | Remove trailing whitespace.
rtrim :: String -> String

-- | Remove leading and trailing whitesapce.
trim :: String -> String
instance Data.String.IsString Agda.Utils.List1.String1
instance (Data.String.IsString (m a), GHC.Base.Monad m) => Data.String.IsString (Control.Monad.Trans.Reader.ReaderT r m a)
instance (Data.String.IsString (m a), GHC.Base.Monad m) => Data.String.IsString (Control.Monad.Trans.State.Lazy.StateT s m a)


-- | Auxiliary functions for the IO monad.
module Agda.Utils.IO

-- | Catch <a>IOException</a>s.
class CatchIO m
catchIO :: CatchIO m => m a -> (IOException -> m a) -> m a

-- | Print an <a>IOException</a> without the call stack.
showIOException :: Exception e => e -> String
instance Agda.Utils.IO.CatchIO GHC.Types.IO
instance Agda.Utils.IO.CatchIO m => Agda.Utils.IO.CatchIO (Control.Monad.Trans.Writer.Lazy.WriterT w m)
instance Agda.Utils.IO.CatchIO m => Agda.Utils.IO.CatchIO (Control.Monad.Trans.State.Lazy.StateT s m)


-- | Collection size.
--   
--   For <tt>TermSize</tt> see <a>Agda.Syntax.Internal</a>.
module Agda.Utils.Size

-- | The size of a collection (i.e., its length).
class Sized a

-- | Strict size computation.
--   
--   Anti-patterns: <tt>size xs == n</tt> where <tt>n</tt> is <tt>0</tt>,
--   <tt>1</tt> or another number that is likely smaller than <tt>size
--   xs</tt>. Similar for <tt>size xs &gt;= 1</tt> etc. Use <a>natSize</a>
--   instead.
--   
--   See
--   <a>https://wiki.haskell.org/Haskell_programming_tips#Don.27t_ask_for_the_length_of_a_list_when_you_don.27t_need_it</a>
--   .
size :: Sized a => a -> Int

-- | Strict size computation.
--   
--   Anti-patterns: <tt>size xs == n</tt> where <tt>n</tt> is <tt>0</tt>,
--   <tt>1</tt> or another number that is likely smaller than <tt>size
--   xs</tt>. Similar for <tt>size xs &gt;= 1</tt> etc. Use <a>natSize</a>
--   instead.
--   
--   See
--   <a>https://wiki.haskell.org/Haskell_programming_tips#Don.27t_ask_for_the_length_of_a_list_when_you_don.27t_need_it</a>
--   .
size :: (Sized a, Foldable t, t b ~ a) => a -> Int

-- | Lazily compute a (possibly infinite) size.
--   
--   Use when comparing a size against a fixed number.
natSize :: Sized a => a -> Peano

-- | Lazily compute a (possibly infinite) size.
--   
--   Use when comparing a size against a fixed number.
natSize :: (Sized a, Foldable t, t b ~ a) => a -> Peano

-- | Thing decorated with its size. The thing should fit into main memory,
--   thus, the size is an <tt>Int</tt>.
data SizedThing a
SizedThing :: !Int -> a -> SizedThing a
[theSize] :: SizedThing a -> !Int
[sizedThing] :: SizedThing a -> a

-- | Cache the size of an object.
sizeThing :: Sized a => a -> SizedThing a

-- | The natural numbers in (lazy) unary notation.
data () => Peano
Zero :: Peano
Succ :: Peano -> Peano
instance Agda.Utils.Size.Sized (Agda.Utils.Size.SizedThing a)
instance Agda.Utils.Null.Null a => Agda.Utils.Null.Null (Agda.Utils.Size.SizedThing a)
instance Agda.Utils.Size.Sized [a]
instance Agda.Utils.Size.Sized (Data.Set.Internal.Set a)
instance Agda.Utils.Size.Sized (Data.HashMap.Internal.HashMap k a)
instance Agda.Utils.Size.Sized (Data.HashSet.Internal.HashSet a)
instance Agda.Utils.Size.Sized (Data.IntMap.Internal.IntMap a)
instance Agda.Utils.Size.Sized (Agda.Utils.List1.List1 a)
instance Agda.Utils.Size.Sized (Data.Map.Internal.Map k a)
instance Agda.Utils.Size.Sized (Data.Sequence.Internal.Seq a)
instance Agda.Utils.Size.Sized Data.IntSet.Internal.IntSet

module Agda.Utils.Permutation

-- | Partial permutations. Examples:
--   
--   <tt>permute [1,2,0] [x0,x1,x2] = [x1,x2,x0]</tt> (proper permutation).
--   
--   <tt>permute [1,0] [x0,x1,x2] = [x1,x0]</tt> (partial permuation).
--   
--   <tt>permute [1,0,1,2] [x0,x1,x2] = [x1,x0,x1,x2]</tt> (not a
--   permutation because not invertible).
--   
--   Agda typing would be: <tt>Perm : {m : Nat}(n : Nat) -&gt; Vec (Fin n)
--   m -&gt; Permutation</tt> <tt>m</tt> is the <a>size</a> of the
--   permutation.
data Permutation
Perm :: Int -> [Int] -> Permutation
[permRange] :: Permutation -> Int
[permPicks] :: Permutation -> [Int]

-- | <tt>permute [1,2,0] [x0,x1,x2] = [x1,x2,x0]</tt> More precisely,
--   <tt>permute indices list = sublist</tt>, generates <tt>sublist</tt>
--   from <tt>list</tt> by picking the elements of list as indicated by
--   <tt>indices</tt>. <tt>permute [1,3,0] [x0,x1,x2,x3] = [x1,x3,x0]</tt>
--   
--   Agda typing: <tt>permute (Perm {m} n is) : Vec A m -&gt; Vec A n</tt>
--   
--   Precondition for <tt><a>permute</a> (<a>Perm</a> _ is) xs</tt>: Every
--   index in <tt>is</tt> must be non-negative and, if <tt>xs</tt> is
--   finite, then every index must also be smaller than the length of
--   <tt>xs</tt>.
--   
--   The implementation is supposed to be extensionally equal to the
--   following one (if different exceptions are identified), but in some
--   cases more efficient: <tt> permute (<a>Perm</a> _ is) xs = <a>map</a>
--   (xs <a>!!</a>) is </tt>
permute :: Permutation -> [a] -> [a]

-- | Invert a Permutation on a partial finite int map. <tt>inversePermute
--   perm f = f'</tt> such that <tt>permute perm f' = f</tt>
--   
--   Example, with map represented as <tt>[Maybe a]</tt>: <tt> f =
--   [Nothing, Just a, Just b ] perm = Perm 4 [3,0,2] f' = [ Just a ,
--   Nothing , Just b , Nothing ] </tt> Zipping <tt>perm</tt> with
--   <tt>f</tt> gives <tt>[(0,a),(2,b)]</tt>, after compression with
--   <tt>catMaybes</tt>. This is an <tt>IntMap</tt> which can easily
--   written out into a substitution again.
class InversePermute a b
inversePermute :: InversePermute a b => Permutation -> a -> b

-- | Identity permutation.
idP :: Int -> Permutation

-- | Restrict a permutation to work on <tt>n</tt> elements, discarding
--   picks <tt>&gt;=n</tt>.
takeP :: Int -> Permutation -> Permutation

-- | Pick the elements that are not picked by the permutation.
droppedP :: Permutation -> Permutation

-- | <tt>liftP k</tt> takes a <tt>Perm {m} n</tt> to a <tt>Perm {m+k}
--   (n+k)</tt>. Analogous to <a>liftS</a>, but Permutations operate on de
--   Bruijn LEVELS, not indices.
liftP :: Int -> Permutation -> Permutation

-- | <pre>
--   permute (compose p1 p2) == permute p1 . permute p2
--   </pre>
composeP :: Permutation -> Permutation -> Permutation

-- | <tt>invertP err p</tt> is the inverse of <tt>p</tt> where defined,
--   otherwise defaults to <tt>err</tt>. <tt>composeP p (invertP err p) ==
--   p</tt>
invertP :: Int -> Permutation -> Permutation

-- | Turn a possible non-surjective permutation into a surjective
--   permutation.
compactP :: Permutation -> Permutation

-- | <pre>
--   permute (reverseP p) xs ==
--       reverse $ permute p $ reverse xs
--   </pre>
--   
--   Example: <tt> permute (reverseP (Perm 4 [1,3,0])) [x0,x1,x2,x3] ==
--   permute (Perm 4 $ map (3-) [0,3,1]) [x0,x1,x2,x3] == permute (Perm 4
--   [3,0,2]) [x0,x1,x2,x3] == [x3,x0,x2] == reverse [x2,x0,x3] == reverse
--   $ permute (Perm 4 [1,3,0]) [x3,x2,x1,x0] == reverse $ permute (Perm 4
--   [1,3,0]) $ reverse [x0,x1,x2,x3] </tt>
--   
--   With <tt>reverseP</tt>, you can convert a permutation on de Bruijn
--   indices to one on de Bruijn levels, and vice versa.
reverseP :: Permutation -> Permutation

-- | <tt>permPicks (flipP p) = permute p (downFrom (permRange p))</tt> or
--   <tt>permute (flipP (Perm n xs)) [0..n-1] = permute (Perm n xs)
--   (downFrom n)</tt>
--   
--   Can be use to turn a permutation from (de Bruijn) levels to levels to
--   one from levels to indices.
--   
--   See <a>numberPatVars</a>.
flipP :: Permutation -> Permutation

-- | <tt>expandP i n π</tt> in the domain of <tt>π</tt> replace the
--   <i>i</i>th element by <i>n</i> elements.
expandP :: Int -> Int -> Permutation -> Permutation

-- | Stable topologic sort. The first argument decides whether its first
--   argument is an immediate parent to its second argument.
topoSort :: (a -> a -> Bool) -> [a] -> Maybe Permutation
topoSortM :: Monad m => (a -> a -> m Bool) -> [a] -> m (Maybe Permutation)

-- | Delayed dropping which allows undropping.
data Drop a
Drop :: Int -> a -> Drop a

-- | Non-negative number of things to drop.
[dropN] :: Drop a -> Int

-- | Where to drop from.
[dropFrom] :: Drop a -> a

-- | Things that support delayed dropping.
class DoDrop a
doDrop :: DoDrop a => Drop a -> a
dropMore :: DoDrop a => Int -> Drop a -> Drop a
unDrop :: DoDrop a => Int -> Drop a -> Drop a
instance GHC.Generics.Generic Agda.Utils.Permutation.Permutation
instance GHC.Classes.Eq Agda.Utils.Permutation.Permutation
instance Data.Traversable.Traversable Agda.Utils.Permutation.Drop
instance Data.Foldable.Foldable Agda.Utils.Permutation.Drop
instance GHC.Base.Functor Agda.Utils.Permutation.Drop
instance GHC.Show.Show a => GHC.Show.Show (Agda.Utils.Permutation.Drop a)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.Utils.Permutation.Drop a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Utils.Permutation.Drop a)
instance Agda.Utils.Permutation.DoDrop [a]
instance Agda.Utils.Permutation.DoDrop Agda.Utils.Permutation.Permutation
instance Agda.Utils.Permutation.InversePermute [GHC.Maybe.Maybe a] [(GHC.Types.Int, a)]
instance Agda.Utils.Permutation.InversePermute [GHC.Maybe.Maybe a] (Data.IntMap.Internal.IntMap a)
instance Agda.Utils.Permutation.InversePermute [GHC.Maybe.Maybe a] [GHC.Maybe.Maybe a]
instance Agda.Utils.Permutation.InversePermute (GHC.Types.Int -> a) [GHC.Maybe.Maybe a]
instance GHC.Show.Show Agda.Utils.Permutation.Permutation
instance Agda.Utils.Size.Sized Agda.Utils.Permutation.Permutation
instance Agda.Utils.Null.Null Agda.Utils.Permutation.Permutation
instance Control.DeepSeq.NFData Agda.Utils.Permutation.Permutation

module Agda.Utils.ProfileOptions

-- | Various things that can be measured when checking an Agda development.
--   Turned on with the `--profile` flag, for instance `--profile=sharing`
--   to turn on the <a>Sharing</a> option. <a>Internal</a>, <a>Modules</a>,
--   and <a>Definitions</a> are mutually exclusive.
--   
--   NOTE: Changing this data type requires bumping the interface version
--   number in <a>currentInterfaceVersion</a>.
data ProfileOption

-- | Measure time taken by various parts of the system (type checking,
--   serialization, etc)
Internal :: ProfileOption

-- | Measure time spent on individual (Agda) modules
Modules :: ProfileOption

-- | Measure time spent on individual (Agda) definitions
Definitions :: ProfileOption

-- | Measure things related to sharing
Sharing :: ProfileOption

-- | Collect detailed statistics about serialization
Serialize :: ProfileOption

-- | Collect statistics about constraint solving
Constraints :: ProfileOption

-- | Count number of created metavariables
Metas :: ProfileOption

-- | Measure time of interactive commands
Interactive :: ProfileOption

-- | Collect statistics about conversion checking
Conversion :: ProfileOption

-- | Collect statistics about instance search
Instances :: ProfileOption

-- | A set of <a>ProfileOption</a>s
data ProfileOptions

-- | The empty set of profiling options.
noProfileOptions :: ProfileOptions

-- | Parse and add a profiling option to a set of profiling options.
--   Returns <a>Left</a> with a helpful error message if the option doesn't
--   parse or if it's incompatible with existing options. The special
--   string "all" adds all options compatible with the given set and
--   prefering the first of incompatible options. So `--profile=all` sets
--   <a>Internal</a> over <a>Modules</a> and <a>Definitions</a>, but
--   `--profile=modules --profile=all` sets <a>Modules</a> and not
--   <a>Internal</a>.
addProfileOption :: String -> ProfileOptions -> Either String ProfileOptions

-- | Check if a given profiling option is present in a set of profiling
--   options.
containsProfileOption :: ProfileOption -> ProfileOptions -> Bool

-- | Use only for serialization.
profileOptionsToList :: ProfileOptions -> [ProfileOption]

-- | Use only for serialization.
profileOptionsFromList :: [ProfileOption] -> ProfileOptions

-- | Strings accepted by <a>addProfileOption</a>
validProfileOptionStrings :: [String]
instance GHC.Generics.Generic Agda.Utils.ProfileOptions.ProfileOption
instance GHC.Enum.Bounded Agda.Utils.ProfileOptions.ProfileOption
instance GHC.Enum.Enum Agda.Utils.ProfileOptions.ProfileOption
instance GHC.Classes.Ord Agda.Utils.ProfileOptions.ProfileOption
instance GHC.Classes.Eq Agda.Utils.ProfileOptions.ProfileOption
instance GHC.Show.Show Agda.Utils.ProfileOptions.ProfileOption
instance Agda.Utils.Null.Null Agda.Utils.ProfileOptions.ProfileOptions
instance Control.DeepSeq.NFData Agda.Utils.ProfileOptions.ProfileOptions
instance GHC.Classes.Eq Agda.Utils.ProfileOptions.ProfileOptions
instance GHC.Show.Show Agda.Utils.ProfileOptions.ProfileOptions
instance Control.DeepSeq.NFData Agda.Utils.ProfileOptions.ProfileOption


-- | Lists of length at least 2.
--   
--   Import as: <tt> import Agda.Utils.List2 (List2(List2)) import
--   qualified Agda.Utils.List2 as List2 </tt>
module Agda.Utils.List2

-- | Lists of length ≥2.
data List2 a
List2 :: a -> a -> [a] -> List2 a

-- | Safe. O(1).
head :: List2 a -> a

-- | Safe. O(1).
tail :: List2 a -> List1 a

-- | Safe. O(n).
init :: List2 a -> List1 a
break :: (a -> Bool) -> List2 a -> ([a], [a])

-- | O(1).
cons :: a -> List1 a -> List2 a

-- | O(length first list).
append :: List1 a -> List1 a -> List2 a

-- | O(length first list).
appendList :: List2 a -> [a] -> List2 a

-- | Unsafe! O(1).
fromList1 :: List1 a -> List2 a

-- | Safe. O(1).
toList1 :: List2 a -> List1 a

-- | Safe. O(1).
fromListMaybe :: [a] -> Maybe (List2 a)

-- | Safe. O(1).
fromList1Maybe :: List1 a -> Maybe (List2 a)

-- | Any <a>List1</a> is either a singleton or a <a>List2</a>. O(1).
fromList1Either :: List1 a -> Either a (List2 a)

-- | Inverse of <a>fromList1Either</a>. O(1).
toList1Either :: Either a (List2 a) -> List1 a

-- | The <a>toList</a> function extracts a list of <tt>Item l</tt> from the
--   structure <tt>l</tt>. It should satisfy fromList . toList = id.
toList :: IsList l => l -> [Item l]
instance Data.Traversable.Traversable Agda.Utils.List2.List2
instance Data.Foldable.Foldable Agda.Utils.List2.List2
instance GHC.Base.Functor Agda.Utils.List2.List2
instance GHC.Show.Show a => GHC.Show.Show (Agda.Utils.List2.List2 a)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.Utils.List2.List2 a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Utils.List2.List2 a)
instance GHC.IsList.IsList (Agda.Utils.List2.List2 a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Utils.List2.List2 a)


-- | Utilities for the <a>Either</a> type.
module Agda.Utils.Either

-- | Loop while we have an exception.
whileLeft :: Monad m => (a -> Either b c) -> (a -> b -> m a) -> (a -> c -> m d) -> a -> m d

-- | Monadic version of <a>either</a> with a different argument ordering.
caseEitherM :: Monad m => m (Either a b) -> (a -> m c) -> (b -> m c) -> m c

-- | 'Either _ b' is a functor.
mapLeft :: (a -> c) -> Either a b -> Either c b

-- | 'Either a' is a functor.
mapRight :: (b -> d) -> Either a b -> Either a d

-- | <a>Either</a> is bitraversable. Note: From <tt>base &gt;=
--   4.10.0.0</tt> already present in <a>Bitraversable</a>.
traverseEither :: Functor f => (a -> f c) -> (b -> f d) -> Either a b -> f (Either c d)

-- | Return <a>True</a> if the given value is a <a>Left</a>-value,
--   <a>False</a> otherwise.
--   
--   <h4><b>Examples</b></h4>
--   
--   Basic usage:
--   
--   <pre>
--   &gt;&gt;&gt; isLeft (Left "foo")
--   True
--   
--   &gt;&gt;&gt; isLeft (Right 3)
--   False
--   </pre>
--   
--   Assuming a <a>Left</a> value signifies some sort of error, we can use
--   <a>isLeft</a> to write a very simple error-reporting function that
--   does absolutely nothing in the case of success, and outputs "ERROR" if
--   any error occurred.
--   
--   This example shows how <a>isLeft</a> might be used to avoid pattern
--   matching when one does not care about the value contained in the
--   constructor:
--   
--   <pre>
--   &gt;&gt;&gt; import Control.Monad ( when )
--   
--   &gt;&gt;&gt; let report e = when (isLeft e) $ putStrLn "ERROR"
--   
--   &gt;&gt;&gt; report (Right 1)
--   
--   &gt;&gt;&gt; report (Left "parse error")
--   ERROR
--   </pre>
isLeft :: Either a b -> Bool

-- | Return <a>True</a> if the given value is a <a>Right</a>-value,
--   <a>False</a> otherwise.
--   
--   <h4><b>Examples</b></h4>
--   
--   Basic usage:
--   
--   <pre>
--   &gt;&gt;&gt; isRight (Left "foo")
--   False
--   
--   &gt;&gt;&gt; isRight (Right 3)
--   True
--   </pre>
--   
--   Assuming a <a>Left</a> value signifies some sort of error, we can use
--   <a>isRight</a> to write a very simple reporting function that only
--   outputs "SUCCESS" when a computation has succeeded.
--   
--   This example shows how <a>isRight</a> might be used to avoid pattern
--   matching when one does not care about the value contained in the
--   constructor:
--   
--   <pre>
--   &gt;&gt;&gt; import Control.Monad ( when )
--   
--   &gt;&gt;&gt; let report e = when (isRight e) $ putStrLn "SUCCESS"
--   
--   &gt;&gt;&gt; report (Left "parse error")
--   
--   &gt;&gt;&gt; report (Right 1)
--   SUCCESS
--   </pre>
isRight :: Either a b -> Bool

-- | Analogue of <a>fromMaybe</a>.
fromLeft :: (b -> a) -> Either a b -> a

-- | Analogue of <a>fromMaybe</a>.
fromRight :: (a -> b) -> Either a b -> b

-- | Analogue of <a>fromMaybeM</a>.
fromLeftM :: Monad m => (b -> m a) -> m (Either a b) -> m a

-- | Analogue of <a>fromMaybeM</a>.
fromRightM :: Monad m => (a -> m b) -> m (Either a b) -> m b

-- | Safe projection from <a>Left</a>.
--   
--   <pre>
--   maybeLeft (Left a) = Just a
--   maybeLeft Right{}  = Nothing
--   </pre>
maybeLeft :: Either a b -> Maybe a

-- | Safe projection from <a>Right</a>.
--   
--   <pre>
--   maybeRight (Right b) = Just b
--   maybeRight Left{}    = Nothing
--   </pre>
maybeRight :: Either a b -> Maybe b

-- | Returns <tt><a>Just</a> input_with_tags_stripped</tt> if all elements
--   are to the <a>Left</a>, and otherwise <a>Nothing</a>.
allLeft :: [Either a b] -> Maybe [a]

-- | Returns <tt><a>Just</a> input_with_tags_stripped</tt> if all elements
--   are to the right, and otherwise <a>Nothing</a>.
--   
--   <pre>
--   allRight xs ==
--     if all isRight xs then
--       Just (map ((Right x) -&gt; x) xs)
--      else
--       Nothing
--   </pre>
allRight :: [Either a b] -> Maybe [b]

-- | Groups a list into alternating chunks of <a>Left</a> and <a>Right</a>
--   values
groupByEither :: forall a b. [Either a b] -> [Either (List1 a) (List1 b)]

-- | Convert <a>Maybe</a> to <tt><a>Either</a> e</tt>, given an error
--   <tt>e</tt> for the <a>Nothing</a> case.
maybeToEither :: e -> Maybe a -> Either e a

-- | Swap tags <a>Left</a> and <a>Right</a>.
swapEither :: Either a b -> Either b a

module Agda.Utils.Monad

-- | Finally for the <tt>Error</tt> class. Errors in the finally part take
--   precedence over prior errors.
finally :: MonadError e m => m a -> m () -> m a

-- | Bracket without failure. Typically used to preserve state.
bracket_ :: Monad m => m a -> (a -> m ()) -> m b -> m b
andM :: (Foldable f, Monad m) => f (m Bool) -> m Bool

-- | A monadic version of <tt><a>mapMaybe</a> :: (a -&gt; Maybe b) -&gt;
--   [a] -&gt; [b]</tt>.
mapMaybeM :: Monad m => (a -> m (Maybe b)) -> [a] -> m [b]

-- | A monadic version of <tt><a>dropWhile</a> :: (a -&gt; Bool) -&gt; [a]
--   -&gt; [a]</tt>.
dropWhileM :: Monad m => (a -> m Bool) -> [a] -> m [a]
concatMapM :: Monad m => (a -> m [b]) -> [a] -> m [b]

-- | Monadic if-then-else.
ifM :: Monad m => m Bool -> m a -> m a -> m a
unlessM :: Monad m => m Bool -> m () -> m ()

-- | Like <a>guard</a>, but raise given error when condition fails.
guardWithError :: MonadError e m => e -> Bool -> m ()

-- | Try a computation, return <a>Nothing</a> if an <tt>Error</tt> occurs.
tryMaybe :: (MonadError e m, Functor m) => m a -> m (Maybe a)

-- | Output a single value.
tell1 :: (Monoid ws, Singleton w ws, MonadWriter ws m) => w -> m ()

-- | Binary bind.
(==<<) :: Monad m => (a -> b -> m c) -> (m a, m b) -> m c

-- | Strict <tt>ap</tt>
(<*!>) :: Monad m => m (a -> b) -> m a -> m b
infixl 4 <*!>
whenM :: Monad m => m Bool -> m () -> m ()

-- | Monadic guard.
guardM :: (Monad m, MonadPlus m) => m Bool -> m ()

-- | <pre>
--   ifNotM mc = ifM (not <a>$</a> mc)
--   </pre>
ifNotM :: Monad m => m Bool -> m a -> m a -> m a

-- | Lazy monadic conjunction.
and2M :: Monad m => m Bool -> m Bool -> m Bool
allM :: (Foldable f, Monad m) => f a -> (a -> m Bool) -> m Bool

-- | Lazy monadic disjunction.
or2M :: Monad m => m Bool -> m Bool -> m Bool
orM :: (Foldable f, Monad m) => f (m Bool) -> m Bool
anyM :: (Foldable f, Monad m) => f a -> (a -> m Bool) -> m Bool

-- | Lazy monadic disjunction with <tt>Either</tt> truth values. Returns
--   the last error message if all fail.
altM1 :: Monad m => (a -> m (Either err b)) -> [a] -> m (Either err b)

-- | Lazy monadic disjunction with accumulation of errors in a monoid.
--   Errors are discarded if we succeed.
orEitherM :: (Monoid e, Monad m, Functor m) => [m (Either e b)] -> m (Either e b)

-- | Generalized version of <tt>traverse_ :: Applicative m =&gt; (a -&gt; m
--   ()) -&gt; [a] -&gt; m ()</tt> Executes effects and collects results in
--   left-to-right order. Works best with left-associative monoids.
--   
--   Note that there is an alternative
--   
--   <pre>
--   mapM' f t = foldr mappend mempty <a>$</a> mapM f t
--   </pre>
--   
--   that collects results in right-to-left order (effects still
--   left-to-right). It might be preferable for right associative monoids.
mapM' :: (Foldable t, Applicative m, Monoid b) => (a -> m b) -> t a -> m b

-- | Generalized version of <tt>for_ :: Applicative m =&gt; [a] -&gt; (a
--   -&gt; m ()) -&gt; m ()</tt>
forM' :: (Foldable t, Applicative m, Monoid b) => t a -> (a -> m b) -> m b
mapMM :: (Traversable t, Monad m) => (a -> m b) -> m (t a) -> m (t b)
forMM :: (Traversable t, Monad m) => m (t a) -> (a -> m b) -> m (t b)
mapMM_ :: (Foldable t, Monad m) => (a -> m ()) -> m (t a) -> m ()
forMM_ :: (Foldable t, Monad m) => m (t a) -> (a -> m ()) -> m ()

-- | A version of <tt><a>mapMaybeM</a></tt> with a computation for the
--   input list.
mapMaybeMM :: Monad m => (a -> m (Maybe b)) -> m [a] -> m [b]

-- | The <tt>for</tt> version of <a>mapMaybeM</a>.
forMaybeM :: Monad m => [a] -> (a -> m (Maybe b)) -> m [b]

-- | The <tt>for</tt> version of <a>mapMaybeMM</a>.
forMaybeMM :: Monad m => m [a] -> (a -> m (Maybe b)) -> m [b]

-- | A monadic version of <tt><tt>dropWhileEnd</tt> :: (a -&gt; Bool) -&gt;
--   [a] -&gt; m [a]</tt>. Effects happen starting at the end of the list
--   until <tt>p</tt> becomes false.
dropWhileEndM :: Monad m => (a -> m Bool) -> [a] -> m [a]

-- | A `<tt>monadic'</tt> version of @<tt>partition</tt> :: (a -&gt; Bool)
--   -&gt; [a] -&gt; ([a],[a])
partitionM :: (Functor m, Applicative m) => (a -> m Bool) -> [a] -> m ([a], [a])

-- | Translates <a>Maybe</a> to <a>MonadPlus</a>.
fromMaybeMP :: MonadPlus m => Maybe a -> m a

-- | Generalises the <a>catMaybes</a> function from lists to an arbitrary
--   <a>MonadPlus</a>.
catMaybesMP :: MonadPlus m => m (Maybe a) -> m a

-- | Branch over elements of a monadic <a>Foldable</a> data structure.
scatterMP :: (MonadPlus m, Foldable t) => m (t a) -> m a

-- | Run a command, catch the exception and return it.
tryCatch :: (MonadError e m, Functor m) => m () -> m (Maybe e)

-- | Restore state after computation.
localState :: MonadState s m => m a -> m a
embedWriter :: (Monoid w, Monad m) => Writer w a -> WriterT w m a

-- | Conditional execution of <a>Applicative</a> expressions. For example,
--   
--   <pre>
--   when debug (putStrLn "Debugging")
--   </pre>
--   
--   will output the string <tt>Debugging</tt> if the Boolean value
--   <tt>debug</tt> is <a>True</a>, and otherwise do nothing.
when :: Applicative f => Bool -> f () -> f ()

-- | The reverse of <a>when</a>.
unless :: Applicative f => Bool -> f () -> f ()

-- | Monads that also support choice and failure.
class (Alternative m, Monad m) => MonadPlus (m :: Type -> Type)

-- | The identity of <a>mplus</a>. It should also satisfy the equations
--   
--   <pre>
--   mzero &gt;&gt;= f  =  mzero
--   v &gt;&gt; mzero   =  mzero
--   </pre>
--   
--   The default definition is
--   
--   <pre>
--   mzero = <a>empty</a>
--   </pre>
mzero :: MonadPlus m => m a

-- | An associative operation. The default definition is
--   
--   <pre>
--   mplus = (<a>&lt;|&gt;</a>)
--   </pre>
mplus :: MonadPlus m => m a -> m a -> m a

-- | An infix synonym for <a>fmap</a>.
--   
--   The name of this operator is an allusion to <a>$</a>. Note the
--   similarities between their types:
--   
--   <pre>
--    ($)  ::              (a -&gt; b) -&gt;   a -&gt;   b
--   (&lt;$&gt;) :: Functor f =&gt; (a -&gt; b) -&gt; f a -&gt; f b
--   </pre>
--   
--   Whereas <a>$</a> is function application, <a>&lt;$&gt;</a> is function
--   application lifted over a <a>Functor</a>.
--   
--   <h4><b>Examples</b></h4>
--   
--   Convert from a <tt><a>Maybe</a> <a>Int</a></tt> to a <tt><a>Maybe</a>
--   <a>String</a></tt> using <a>show</a>:
--   
--   <pre>
--   &gt;&gt;&gt; show &lt;$&gt; Nothing
--   Nothing
--   
--   &gt;&gt;&gt; show &lt;$&gt; Just 3
--   Just "3"
--   </pre>
--   
--   Convert from an <tt><a>Either</a> <a>Int</a> <a>Int</a></tt> to an
--   <tt><a>Either</a> <a>Int</a></tt> <a>String</a> using <a>show</a>:
--   
--   <pre>
--   &gt;&gt;&gt; show &lt;$&gt; Left 17
--   Left 17
--   
--   &gt;&gt;&gt; show &lt;$&gt; Right 17
--   Right "17"
--   </pre>
--   
--   Double each element of a list:
--   
--   <pre>
--   &gt;&gt;&gt; (*2) &lt;$&gt; [1,2,3]
--   [2,4,6]
--   </pre>
--   
--   Apply <a>even</a> to the second element of a pair:
--   
--   <pre>
--   &gt;&gt;&gt; even &lt;$&gt; (2,2)
--   (2,True)
--   </pre>
(<$>) :: Functor f => (a -> b) -> f a -> f b
infixl 4 <$>

-- | Sequential application.
--   
--   A few functors support an implementation of <a>&lt;*&gt;</a> that is
--   more efficient than the default one.
--   
--   <h4><b>Example</b></h4>
--   
--   Used in combination with <tt>(<tt>&lt;$&gt;</tt>)</tt>,
--   <tt>(<a>&lt;*&gt;</a>)</tt> can be used to build a record.
--   
--   <pre>
--   &gt;&gt;&gt; data MyState = MyState {arg1 :: Foo, arg2 :: Bar, arg3 :: Baz}
--   </pre>
--   
--   <pre>
--   &gt;&gt;&gt; produceFoo :: Applicative f =&gt; f Foo
--   </pre>
--   
--   <pre>
--   &gt;&gt;&gt; produceBar :: Applicative f =&gt; f Bar
--   
--   &gt;&gt;&gt; produceBaz :: Applicative f =&gt; f Baz
--   </pre>
--   
--   <pre>
--   &gt;&gt;&gt; mkState :: Applicative f =&gt; f MyState
--   
--   &gt;&gt;&gt; mkState = MyState &lt;$&gt; produceFoo &lt;*&gt; produceBar &lt;*&gt; produceBaz
--   </pre>
(<*>) :: Applicative f => f (a -> b) -> f a -> f b
infixl 4 <*>

-- | Strict version of <a>&lt;$&gt;</a>.
(<$!>) :: Monad m => (a -> b) -> m a -> m b
infixl 4 <$!>

-- | Replace all locations in the input with the same value. The default
--   definition is <tt><a>fmap</a> . <a>const</a></tt>, but this may be
--   overridden with a more efficient version.
--   
--   <h4><b>Examples</b></h4>
--   
--   Perform a computation with <a>Maybe</a> and replace the result with a
--   constant value if it is <a>Just</a>:
--   
--   <pre>
--   &gt;&gt;&gt; 'a' &lt;$ Just 2
--   Just 'a'
--   
--   &gt;&gt;&gt; 'a' &lt;$ Nothing
--   Nothing
--   </pre>
(<$) :: Functor f => a -> f b -> f a
infixl 4 <$


-- | <tt>ListT</tt> done right, see
--   <a>https://www.haskell.org/haskellwiki/ListT_done_right_alternative</a>
--   
--   There is also the <tt>list-t</tt> package on hackage (Nikita Volkov)
--   but it again depends on other packages we do not use yet, so we rather
--   implement the few bits we need afresh.
module Agda.Utils.ListT

-- | Lazy monadic computation of a list of results.
newtype ListT m a
ListT :: m (Maybe (a, ListT m a)) -> ListT m a
[runListT] :: ListT m a -> m (Maybe (a, ListT m a))

-- | Boilerplate function to lift <a>MonadReader</a> through the
--   <a>ListT</a> transformer.
mapListT :: (m (Maybe (a, ListT m a)) -> n (Maybe (b, ListT n b))) -> ListT m a -> ListT n b

-- | Inverse to <a>mapListT</a>.
unmapListT :: (ListT m a -> ListT n b) -> m (Maybe (a, ListT m a)) -> n (Maybe (b, ListT n b))

-- | The empty lazy list.
nilListT :: Monad m => ListT m a

-- | Consing a value to a lazy list.
consListT :: Monad m => a -> ListT m a -> ListT m a

-- | Singleton lazy list.
sgListT :: Monad m => a -> ListT m a

-- | Case distinction over lazy list.
caseListT :: Monad m => ListT m a -> m b -> (a -> ListT m a -> m b) -> m b

-- | Folding a lazy list, effects left-to-right.
foldListT :: Monad m => (a -> m b -> m b) -> m b -> ListT m a -> m b

-- | Lazy monadic disjunction of lazy monadic list, effects left-to-right
anyListT :: Monad m => ListT m a -> (a -> m Bool) -> m Bool

-- | Lazy monadic conjunction of lazy monadic list, effects left-to-right
allListT :: Monad m => ListT m a -> (a -> m Bool) -> m Bool

-- | Force all values in the lazy list, effects left-to-right
sequenceListT :: Monad m => ListT m a -> m [a]

-- | The join operation of the <tt>ListT m</tt> monad.
concatListT :: Monad m => ListT m (ListT m a) -> ListT m a

-- | We can `<tt>run'</tt> a computation of a <a>ListT</a> as it is monadic
--   itself.
runMListT :: Monad m => m (ListT m a) -> ListT m a

-- | Monadic cons.
consMListT :: Monad m => m a -> ListT m a -> ListT m a

-- | Monadic singleton.
sgMListT :: Monad m => m a -> ListT m a

-- | Extending a monadic function to <a>ListT</a>.
mapMListT :: Monad m => (a -> m b) -> ListT m a -> ListT m b

-- | Alternative implementation using <a>foldListT</a>.
mapMListT_alt :: Monad m => (a -> m b) -> ListT m a -> ListT m b

-- | Change from one monad to another
liftListT :: (Monad m, Monad m') => (forall a. m a -> m' a) -> ListT m a -> ListT m' a
instance GHC.Base.Functor m => GHC.Base.Functor (Agda.Utils.ListT.ListT m)
instance GHC.Base.Monad m => GHC.Base.Semigroup (Agda.Utils.ListT.ListT m a)
instance GHC.Base.Monad m => GHC.Base.Monoid (Agda.Utils.ListT.ListT m a)
instance (GHC.Base.Functor m, GHC.Base.Applicative m, GHC.Base.Monad m) => GHC.Base.Alternative (Agda.Utils.ListT.ListT m)
instance (GHC.Base.Functor m, GHC.Base.Applicative m, GHC.Base.Monad m) => GHC.Base.MonadPlus (Agda.Utils.ListT.ListT m)
instance (GHC.Base.Functor m, GHC.Base.Applicative m, GHC.Base.Monad m) => GHC.Base.Applicative (Agda.Utils.ListT.ListT m)
instance (GHC.Base.Functor m, GHC.Base.Applicative m, GHC.Base.Monad m) => GHC.Base.Monad (Agda.Utils.ListT.ListT m)
instance Control.Monad.Trans.Class.MonadTrans Agda.Utils.ListT.ListT
instance (GHC.Base.Applicative m, Control.Monad.IO.Class.MonadIO m) => Control.Monad.IO.Class.MonadIO (Agda.Utils.ListT.ListT m)
instance (GHC.Base.Applicative m, Control.Monad.Reader.Class.MonadReader r m) => Control.Monad.Reader.Class.MonadReader r (Agda.Utils.ListT.ListT m)
instance (GHC.Base.Applicative m, Control.Monad.State.Class.MonadState s m) => Control.Monad.State.Class.MonadState s (Agda.Utils.ListT.ListT m)
instance GHC.Base.Monad m => Control.Monad.Fail.MonadFail (Agda.Utils.ListT.ListT m)


-- | Operations on file names.
module Agda.Utils.FileName

-- | Paths which are known to be absolute.
--   
--   Note that the <a>Eq</a> and <a>Ord</a> instances do not check if
--   different paths point to the same files or directories.
newtype AbsolutePath
AbsolutePath :: Text -> AbsolutePath

-- | Extract the <a>AbsolutePath</a> to be used as <a>FilePath</a>.
filePath :: AbsolutePath -> FilePath

-- | Constructs <a>AbsolutePath</a>s.
--   
--   Precondition: The path must be absolute and valid.
mkAbsolute :: FilePath -> AbsolutePath

-- | Makes the path absolute.
--   
--   This function may raise an <tt>__IMPOSSIBLE__</tt> error if
--   <a>canonicalizePath</a> does not return an absolute path.
absolute :: FilePath -> IO AbsolutePath

-- | Resolve symlinks etc. Preserves <a>sameFile</a>.
canonicalizeAbsolutePath :: AbsolutePath -> IO AbsolutePath

-- | Tries to establish if the two file paths point to the same file (or
--   directory). False negatives may be returned.
sameFile :: AbsolutePath -> AbsolutePath -> IO Bool

-- | Case-sensitive <a>doesFileExist</a> for Windows.
--   
--   This is case-sensitive only on the file name part, not on the
--   directory part. (Ideally, path components coming from module name
--   components should be checked case-sensitively and the other path
--   components should be checked case insensitively.)
doesFileExistCaseSensitive :: FilePath -> IO Bool

-- | True if the first file is newer than the second file. If a file
--   doesn't exist it is considered to be infinitely old.
isNewerThan :: FilePath -> FilePath -> IO Bool

-- | A partial version of <a>makeRelative</a> with flipped arguments,
--   returning <a>Nothing</a> if the given path cannot be relativized to
--   the given <tt>root</tt>.
relativizeAbsolutePath :: AbsolutePath -> AbsolutePath -> Maybe FilePath
instance Control.DeepSeq.NFData Agda.Utils.FileName.AbsolutePath
instance Data.Hashable.Class.Hashable Agda.Utils.FileName.AbsolutePath
instance GHC.Classes.Ord Agda.Utils.FileName.AbsolutePath
instance GHC.Classes.Eq Agda.Utils.FileName.AbsolutePath
instance GHC.Show.Show Agda.Utils.FileName.AbsolutePath


-- | Instead of checking time-stamps we compute a hash of the module source
--   and store it in the interface file. This module contains the functions
--   to do that.
module Agda.Utils.Hash
type Hash = Word64
hashByteString :: ByteString -> Hash
hashTextFile :: AbsolutePath -> IO Hash

-- | Hashes a piece of <a>Text</a>.
hashText :: Text -> Hash
combineHashes :: [Hash] -> Hash

-- | Hashing a module name for unique identifiers.
hashString :: String -> Word64

module Agda.Interaction.Options.Warnings

-- | A <tt>WarningMode</tt> has two components: a set of warnings to be
--   displayed and a flag stating whether warnings should be turned into
--   fatal errors.
data WarningMode
WarningMode :: Set WarningName -> Bool -> WarningMode
[_warningSet] :: WarningMode -> Set WarningName
[_warn2Error] :: WarningMode -> Bool
warningSet :: Lens' WarningMode (Set WarningName)
warn2Error :: Lens' WarningMode Bool
lensSingleWarning :: WarningName -> Lens' WarningMode Bool

-- | The <tt>defaultWarningMode</tt> is a curated set of warnings covering
--   non-fatal errors and disabling style-related ones
defaultWarningSet :: String
allWarnings :: Set WarningName
usualWarnings :: Set WarningName
noWarnings :: Set WarningName
unsolvedWarnings :: Set WarningName
incompleteMatchWarnings :: Set WarningName
errorWarnings :: Set WarningName

-- | Warnings enabled by <tt>--exact-split</tt>.
exactSplitWarnings :: Set WarningName
defaultWarningMode :: WarningMode

-- | Some warnings are errors and cannot be turned off.
data WarningModeError

-- | Unknown warning.
Unknown :: Text -> WarningModeError

-- | Warning that cannot be disabled.
NoNoError :: Text -> WarningModeError
prettyWarningModeError :: WarningModeError -> Text

-- | <tt>warningModeUpdate str</tt> computes the action of <tt>str</tt>
--   over the current <tt>WarningMode</tt>: it may reset the set of
--   warnings, add or remove a specific flag or demand that any warning be
--   turned into an error
warningModeUpdate :: String -> Either WarningModeError WarningModeUpdate

-- | Common sets of warnings
warningSets :: [(String, (Set WarningName, String))]

-- | The <tt>WarningName</tt> data enumeration is meant to have a
--   one-to-one correspondance to existing warnings in the codebase.
data WarningName
OptionRenamed_ :: WarningName

-- | Some warning could not be set or unset. Parser Warnings
WarningProblem_ :: WarningName
OverlappingTokensWarning_ :: WarningName
UnsupportedAttribute_ :: WarningName
MultipleAttributes_ :: WarningName
LibUnknownField_ :: WarningName
EmptyAbstract_ :: WarningName
EmptyConstructor_ :: WarningName
EmptyField_ :: WarningName
EmptyGeneralize_ :: WarningName
EmptyInstance_ :: WarningName
EmptyMacro_ :: WarningName
EmptyMutual_ :: WarningName
EmptyPostulate_ :: WarningName
EmptyPrimitive_ :: WarningName
EmptyPrivate_ :: WarningName
EmptyRewritePragma_ :: WarningName
EmptyWhere_ :: WarningName
HiddenGeneralize_ :: WarningName
InvalidCatchallPragma_ :: WarningName
InvalidConstructor_ :: WarningName
InvalidConstructorBlock_ :: WarningName
InvalidCoverageCheckPragma_ :: WarningName
InvalidNoPositivityCheckPragma_ :: WarningName
InvalidNoUniverseCheckPragma_ :: WarningName
DuplicateRecordDirective_ :: WarningName
InvalidTerminationCheckPragma_ :: WarningName
MissingDeclarations_ :: WarningName
MissingDefinitions_ :: WarningName
NotAllowedInMutual_ :: WarningName
OpenPublicAbstract_ :: WarningName
OpenPublicPrivate_ :: WarningName
PolarityPragmasButNotPostulates_ :: WarningName
PragmaCompiled_ :: WarningName
PragmaNoTerminationCheck_ :: WarningName
ShadowingInTelescope_ :: WarningName
UnknownFixityInMixfixDecl_ :: WarningName
UnknownNamesInFixityDecl_ :: WarningName
UnknownNamesInPolarityPragmas_ :: WarningName
UselessAbstract_ :: WarningName
UselessInstance_ :: WarningName
UselessMacro_ :: WarningName
UselessPrivate_ :: WarningName
AbsurdPatternRequiresNoRHS_ :: WarningName
AsPatternShadowsConstructorOrPatternSynonym_ :: WarningName
PatternShadowsConstructor_ :: WarningName
CantGeneralizeOverSorts_ :: WarningName
ClashesViaRenaming_ :: WarningName
CoverageIssue_ :: WarningName
CoverageNoExactSplit_ :: WarningName
InlineNoExactSplit_ :: WarningName
DeprecationWarning_ :: WarningName
DuplicateUsing_ :: WarningName
FixityInRenamingModule_ :: WarningName
InvalidCharacterLiteral_ :: WarningName
UselessPragma_ :: WarningName
IllformedAsClause_ :: WarningName
InstanceArgWithExplicitArg_ :: WarningName
InstanceWithExplicitArg_ :: WarningName
InstanceNoOutputTypeName_ :: WarningName
InteractionMetaBoundaries_ :: WarningName
InversionDepthReached_ :: WarningName
ModuleDoesntExport_ :: WarningName
NoGuardednessFlag_ :: WarningName
NotInScope_ :: WarningName
NotStrictlyPositive_ :: WarningName
ConstructorDoesNotFitInData_ :: WarningName
CoinductiveEtaRecord_ :: WarningName
UnsupportedIndexedMatch_ :: WarningName
OldBuiltin_ :: WarningName
BuiltinDeclaresIdentifier_ :: WarningName
PlentyInHardCompileTimeMode_ :: WarningName
PragmaCompileErased_ :: WarningName
PragmaCompileList_ :: WarningName
PragmaCompileMaybe_ :: WarningName
NoMain_ :: WarningName
RewriteLHSNotDefinitionOrConstructor_ :: WarningName
RewriteVariablesNotBoundByLHS_ :: WarningName
RewriteVariablesBoundMoreThanOnce_ :: WarningName
RewriteLHSReduces_ :: WarningName
RewriteHeadSymbolIsProjection_ :: WarningName
RewriteHeadSymbolIsProjectionLikeFunction_ :: WarningName
RewriteHeadSymbolIsTypeConstructor_ :: WarningName
RewriteHeadSymbolContainsMetas_ :: WarningName
RewriteConstructorParametersNotGeneral_ :: WarningName
RewriteContainsUnsolvedMetaVariables_ :: WarningName
RewriteBlockedOnProblems_ :: WarningName
RewriteRequiresDefinitions_ :: WarningName
RewriteDoesNotTargetRewriteRelation_ :: WarningName
RewriteBeforeFunctionDefinition_ :: WarningName
RewriteBeforeMutualFunctionDefinition_ :: WarningName
ConfluenceCheckingIncompleteBecauseOfMeta_ :: WarningName
ConfluenceForCubicalNotSupported_ :: WarningName
RewriteMaybeNonConfluent_ :: WarningName
RewriteNonConfluent_ :: WarningName
RewriteAmbiguousRules_ :: WarningName
RewriteMissingRule_ :: WarningName
DuplicateRewriteRule_ :: WarningName
SafeFlagEta_ :: WarningName
SafeFlagInjective_ :: WarningName
SafeFlagNoCoverageCheck_ :: WarningName
SafeFlagNonTerminating_ :: WarningName
SafeFlagNoPositivityCheck_ :: WarningName
SafeFlagNoUniverseCheck_ :: WarningName
SafeFlagPolarity_ :: WarningName
SafeFlagPostulate_ :: WarningName
SafeFlagPragma_ :: WarningName
SafeFlagTerminating_ :: WarningName
SafeFlagWithoutKFlagPrimEraseEquality_ :: WarningName
TerminationIssue_ :: WarningName
UnreachableClauses_ :: WarningName
UnsolvedConstraints_ :: WarningName
UnsolvedInteractionMetas_ :: WarningName
UnsolvedMetaVariables_ :: WarningName
UselessHiding_ :: WarningName
UselessInline_ :: WarningName
UselessPatternDeclarationForRecord_ :: WarningName
UselessPublic_ :: WarningName
UserWarning_ :: WarningName
WithoutKFlagPrimEraseEquality_ :: WarningName
ConflictingPragmaOptions_ :: WarningName
WrongInstanceDeclaration_ :: WarningName
CoInfectiveImport_ :: WarningName
InfectiveImport_ :: WarningName
DuplicateFields_ :: WarningName
TooManyFields_ :: WarningName
MissingTypeSignatureForOpaque_ :: WarningName
NotAffectedByOpaque_ :: WarningName
UnfoldTransparentName_ :: WarningName
UselessOpaque_ :: WarningName
FaceConstraintCannotBeHidden_ :: WarningName
FaceConstraintCannotBeNamed_ :: WarningName
DuplicateInterfaceFiles_ :: WarningName
CustomBackendWarning_ :: WarningName
warningName2String :: WarningName -> String

-- | The flag corresponding to a warning is precisely the name of the
--   constructor minus the trailing underscore.
string2WarningName :: String -> Maybe WarningName

-- | <tt>warningUsage</tt> generated using <tt>warningNameDescription</tt>
usageWarning :: String
instance GHC.Generics.Generic Agda.Interaction.Options.Warnings.WarningModeError
instance GHC.Show.Show Agda.Interaction.Options.Warnings.WarningModeError
instance GHC.Generics.Generic Agda.Interaction.Options.Warnings.WarningName
instance GHC.Enum.Bounded Agda.Interaction.Options.Warnings.WarningName
instance GHC.Enum.Enum Agda.Interaction.Options.Warnings.WarningName
instance GHC.Read.Read Agda.Interaction.Options.Warnings.WarningName
instance GHC.Show.Show Agda.Interaction.Options.Warnings.WarningName
instance GHC.Classes.Ord Agda.Interaction.Options.Warnings.WarningName
instance GHC.Classes.Eq Agda.Interaction.Options.Warnings.WarningName
instance GHC.Generics.Generic Agda.Interaction.Options.Warnings.WarningMode
instance GHC.Show.Show Agda.Interaction.Options.Warnings.WarningMode
instance GHC.Classes.Eq Agda.Interaction.Options.Warnings.WarningMode
instance Control.DeepSeq.NFData Agda.Interaction.Options.Warnings.WarningMode
instance Control.DeepSeq.NFData Agda.Interaction.Options.Warnings.WarningName
instance Control.DeepSeq.NFData Agda.Interaction.Options.Warnings.WarningModeError

module Agda.Interaction.Options.Help

-- | Interface to the <tt>help</tt> function
data Help

-- | General usage information
GeneralHelp :: Help

-- | Specialised usage information about TOPIC
HelpFor :: HelpTopic -> Help

-- | Usage information generation
helpTopicUsage :: HelpTopic -> String

-- | Conversion functions to strings
string2HelpTopic :: String -> Maybe HelpTopic
allHelpTopics :: [(String, HelpTopic)]
instance GHC.Generics.Generic Agda.Interaction.Options.Help.HelpTopic
instance GHC.Show.Show Agda.Interaction.Options.Help.HelpTopic
instance GHC.Classes.Eq Agda.Interaction.Options.Help.HelpTopic
instance GHC.Generics.Generic Agda.Interaction.Options.Help.Help
instance GHC.Show.Show Agda.Interaction.Options.Help.Help
instance GHC.Classes.Eq Agda.Interaction.Options.Help.Help
instance Control.DeepSeq.NFData Agda.Interaction.Options.Help.Help
instance Control.DeepSeq.NFData Agda.Interaction.Options.Help.HelpTopic


-- | Maintaining a list of favorites of some partially ordered type. Only
--   the best elements are kept.
--   
--   To avoid name clashes, import this module qualified, as in <tt> import
--   Agda.Utils.Favorites (Favorites) import qualified Agda.Utils.Favorites
--   as Fav </tt>
module Agda.Utils.Favorites

-- | A list of incomparable favorites.
newtype Favorites a
Favorites :: [a] -> Favorites a
[toList] :: Favorites a -> [a]

-- | Result of comparing a candidate with the current favorites.
data CompareResult a

-- | Great, you are dominating a possibly (empty list of favorites) but
--   there is also a rest that is not dominated. If <tt>null
--   dominated</tt>, then <tt>notDominated</tt> is necessarily the complete
--   list of favorites.
Dominates :: [a] -> [a] -> CompareResult a
[dominated] :: CompareResult a -> [a]
[notDominated] :: CompareResult a -> [a]

-- | Sorry, but you are dominated by that favorite.
IsDominated :: a -> CompareResult a
[dominator] :: CompareResult a -> a

-- | Gosh, got some pretty <tt>a</tt> here, compare with my current
--   favorites! Discard it if there is already one that is better or equal.
--   (Skewed conservatively: faithful to the old favorites.) If there is no
--   match for it, add it, and dispose of all that are worse than
--   <tt>a</tt>.
--   
--   We require a partial ordering. Less is better! (Maybe paradoxically.)
compareWithFavorites :: PartialOrd a => a -> Favorites a -> CompareResult a

-- | Compare a new set of favorites to an old one and discard the new
--   favorites that are dominated by the old ones and vice verse. (Skewed
--   conservatively: faithful to the old favorites.)
--   
--   <pre>
--   compareFavorites new old = (new', old')
--   </pre>
compareFavorites :: PartialOrd a => Favorites a -> Favorites a -> (Favorites a, Favorites a)
unionCompared :: (Favorites a, Favorites a) -> Favorites a

-- | After comparing, do the actual insertion.
insertCompared :: a -> Favorites a -> CompareResult a -> Favorites a

-- | Compare, then insert accordingly. <tt>insert a l = insertCompared a l
--   (compareWithFavorites a l)</tt>
insert :: PartialOrd a => a -> Favorites a -> Favorites a

-- | Insert all the favorites from the first list into the second.
union :: PartialOrd a => Favorites a -> Favorites a -> Favorites a

-- | Construct favorites from elements of a partial order. The result
--   depends on the order of the list if it contains equal elements, since
--   earlier seen elements are favored over later seen equals. The first
--   element of the list is seen first.
fromList :: PartialOrd a => [a] -> Favorites a
instance Agda.Utils.Singleton.Singleton a (Agda.Utils.Favorites.Favorites a)
instance Agda.Utils.Null.Null (Agda.Utils.Favorites.Favorites a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.Utils.Favorites.Favorites a)
instance Data.Foldable.Foldable Agda.Utils.Favorites.Favorites
instance GHC.Classes.Ord a => GHC.Classes.Eq (Agda.Utils.Favorites.Favorites a)
instance Agda.Utils.PartialOrd.PartialOrd a => GHC.Base.Semigroup (Agda.Utils.Favorites.Favorites a)
instance Agda.Utils.PartialOrd.PartialOrd a => GHC.Base.Monoid (Agda.Utils.Favorites.Favorites a)


-- | Partly invertible finite maps.
--   
--   Time complexities are given under the assumption that all relevant
--   instance functions, as well as arguments of function type, take
--   constant time, and "n" is the number of keys involved in the
--   operation.
module Agda.Utils.BiMap

-- | Partial injections from a type to some tag type.
--   
--   The idea is that <a>tag</a> should be injective on its domain: if
--   <tt><a>tag</a> x = <a>tag</a> y = <a>Just</a> i</tt>, then <tt>x =
--   y</tt>. However, this property does not need to hold globally. The
--   preconditions of the <a>BiMap</a> operations below specify for which
--   sets of values <a>tag</a> must be injective.
class HasTag a where {
    type Tag a;
}
tag :: HasTag a => a -> Maybe (Tag a)

-- | Checks if the function <a>tag</a> is injective for the values in the
--   given list for which the function is defined.
tagInjectiveFor :: (Eq v, Eq (Tag v), HasTag v) => [v] -> Bool

-- | Finite maps from <tt>k</tt> to <tt>v</tt>, with a way to quickly get
--   from <tt>v</tt> to <tt>k</tt> for certain values of type <tt>v</tt>
--   (those for which <a>tag</a> is defined).
--   
--   Every value of this type must satisfy <a>biMapInvariant</a>.
data BiMap k v
BiMap :: !Map k v -> !Map (Tag v) k -> BiMap k v
[biMapThere] :: BiMap k v -> !Map k v
[biMapBack] :: BiMap k v -> !Map (Tag v) k

-- | The invariant for <a>BiMap</a>.
biMapInvariant :: (Eq k, Eq v, Ord (Tag v), HasTag v) => BiMap k v -> Bool

-- | Is the value a source key? O(log n).
source :: Ord k => k -> BiMap k v -> Bool

-- | Is the value a target key? O(log n).
target :: Ord (Tag v) => Tag v -> BiMap k v -> Bool

-- | Lookup. O(log n).
lookup :: Ord k => k -> BiMap k v -> Maybe v

-- | Inverse lookup. O(log n).
invLookup :: Ord (Tag v) => Tag v -> BiMap k v -> Maybe k

-- | Singleton map. O(1).
singleton :: HasTag v => k -> v -> BiMap k v

-- | Insertion. Overwrites existing values. O(log n).
--   
--   Precondition: See <a>insertPrecondition</a>.
insert :: (Ord k, HasTag v, Ord (Tag v)) => k -> v -> BiMap k v -> BiMap k v

-- | The precondition for <tt><a>insert</a> k v m</tt>: If <tt>v</tt> has a
--   <a>tag</a> (<tt><a>tag</a> v ≠ <a>Nothing</a></tt>), then <tt>m</tt>
--   must not contain any mapping <tt>k' ↦ v'</tt> for which <tt>k ≠
--   k'</tt> and <tt><a>tag</a> v = <a>tag</a> v'</tt>.
insertPrecondition :: (Eq k, Eq v, Eq (Tag v), HasTag v) => k -> v -> BiMap k v -> Bool

-- | Modifies the value at the given position, if any. If the function
--   returns <a>Nothing</a>, then the value is removed. O(log n).
--   
--   The precondition for <tt><a>alterM</a> f k m</tt> is that, if the
--   value <tt>v</tt> is inserted into <tt>m</tt>, and <tt><a>tag</a>
--   v</tt> is defined, then no key other than <tt>k</tt> may map to a
--   value <tt>v'</tt> for which <tt><a>tag</a> v' = <a>tag</a> v</tt>.
alterM :: forall k v m. (Ord k, Ord (Tag v), HasTag v, Monad m) => (Maybe v -> m (Maybe v)) -> k -> BiMap k v -> m (BiMap k v)

-- | Modifies the value at the given position, if any. If the function
--   returns <a>Nothing</a>, then the value is removed. O(log n).
--   
--   Precondition: See <a>alterPrecondition</a>.
alter :: forall k v. (Ord k, Ord (Tag v), HasTag v) => (Maybe v -> Maybe v) -> k -> BiMap k v -> BiMap k v

-- | The precondition for <tt><a>alter</a> f k m</tt> is that, if the value
--   <tt>v</tt> is inserted into <tt>m</tt>, and <tt><a>tag</a> v</tt> is
--   defined, then no key other than <tt>k</tt> may map to a value
--   <tt>v'</tt> for which <tt><a>tag</a> v' = <a>tag</a> v</tt>.
alterPrecondition :: (Ord k, Eq v, Eq (Tag v), HasTag v) => (Maybe v -> Maybe v) -> k -> BiMap k v -> Bool

-- | Modifies the value at the given position, if any. If the function
--   returns <a>Nothing</a>, then the value is removed. O(log n).
--   
--   Precondition: See <a>updatePrecondition</a>.
update :: (Ord k, Ord (Tag v), HasTag v) => (v -> Maybe v) -> k -> BiMap k v -> BiMap k v

-- | The precondition for <tt><a>update</a> f k m</tt> is that, if the
--   value <tt>v</tt> is inserted into <tt>m</tt>, and <tt><a>tag</a>
--   v</tt> is defined, then no key other than <tt>k</tt> may map to a
--   value <tt>v'</tt> for which <tt><a>tag</a> v' = <a>tag</a> v</tt>.
updatePrecondition :: (Ord k, Eq v, Eq (Tag v), HasTag v) => (v -> Maybe v) -> k -> BiMap k v -> Bool

-- | Modifies the value at the given position, if any. O(log n).
--   
--   Precondition: See <a>adjustPrecondition</a>.
adjust :: (Ord k, Ord (Tag v), HasTag v) => (v -> v) -> k -> BiMap k v -> BiMap k v

-- | The precondition for <tt><a>adjust</a> f k m</tt> is that, if the
--   value <tt>v</tt> is inserted into <tt>m</tt>, and <tt><a>tag</a>
--   v</tt> is defined, then no key other than <tt>k</tt> may map to a
--   value <tt>v'</tt> for which <tt><a>tag</a> v' = <a>tag</a> v</tt>.
adjustPrecondition :: (Ord k, Eq v, Eq (Tag v), HasTag v) => (v -> v) -> k -> BiMap k v -> Bool

-- | Inserts a binding into the map. If a binding for the key already
--   exists, then the value obtained by applying the function to the key,
--   the new value and the old value is inserted, and the old value is
--   returned.
--   
--   Precondition: See <a>insertLookupWithKeyPrecondition</a>.
insertLookupWithKey :: forall k v. (Ord k, Ord (Tag v), HasTag v) => (k -> v -> v -> v) -> k -> v -> BiMap k v -> (Maybe v, BiMap k v)

-- | The precondition for <tt><a>insertLookupWithKey</a> f k v m</tt> is
--   that, if the value <tt>v'</tt> is inserted into <tt>m</tt>, and
--   <tt><a>tag</a> v'</tt> is defined, then no key other than <tt>k</tt>
--   may map to a value <tt>v''</tt> for which <tt><a>tag</a> v'' =
--   <a>tag</a> v'</tt>.
insertLookupWithKeyPrecondition :: (Ord k, Eq v, Eq (Tag v), HasTag v) => (k -> v -> v -> v) -> k -> v -> BiMap k v -> Bool

-- | Changes all the values using the given function, which is also given
--   access to keys. O(n log n).
--   
--   Precondition: See <a>mapWithKeyPrecondition</a>.
mapWithKey :: (Ord k, Ord (Tag v), HasTag v) => (k -> v -> v) -> BiMap k v -> BiMap k v

-- | The precondition for <tt><a>mapWithKey</a> f m</tt>: For any two
--   distinct mappings <tt>k₁ ↦ v₁</tt>, <tt>k₂ ↦ v₂</tt> in <tt>m</tt> for
--   which the tags of <tt>f k₁ v₁</tt> and <tt>f k₂ v₂</tt> are defined
--   the values of <tt>f</tt> must be distinct (<tt>f k₁ v₁ ≠ f k₂
--   v₂</tt>). Furthermore <a>tag</a> must be injective for <tt>{ f k v |
--   (k, v) ∈ m }</tt>.
mapWithKeyPrecondition :: (Eq k, Eq v, Eq (Tag v), HasTag v) => (k -> v -> v) -> BiMap k v -> Bool

-- | Changes all the values using the given function, which is also given
--   access to keys. O(n).
--   
--   Precondition: See <a>mapWithKeyFixedTagsPrecondition</a>. Note that
--   tags must not change.
mapWithKeyFixedTags :: (k -> v -> v) -> BiMap k v -> BiMap k v

-- | The precondition for <tt><a>mapWithKeyFixedTags</a> f m</tt> is that,
--   if <tt>m</tt> maps <tt>k</tt> to <tt>v</tt>, then <tt><a>tag</a> (f k
--   v) == <a>tag</a> v</tt>.
mapWithKeyFixedTagsPrecondition :: (Eq v, Eq (Tag v), HasTag v) => (k -> v -> v) -> BiMap k v -> Bool

-- | Left-biased union. For the time complexity, see <a>union</a>.
--   
--   Precondition: See <a>unionPrecondition</a>.
union :: (Ord k, Ord (Tag v)) => BiMap k v -> BiMap k v -> BiMap k v
unionPrecondition :: (Ord k, Eq v, Eq (Tag v), HasTag v) => BiMap k v -> BiMap k v -> Bool

-- | Conversion from lists of pairs. Later entries take precedence over
--   earlier ones. O(n log n).
--   
--   Precondition: See <a>fromListPrecondition</a>.
fromList :: (Ord k, Ord (Tag v), HasTag v) => [(k, v)] -> BiMap k v
fromListPrecondition :: (Eq k, Eq v, Eq (Tag v), HasTag v) => [(k, v)] -> Bool

-- | Conversion to lists of pairs, with the keys in ascending order. O(n).
toList :: BiMap k v -> [(k, v)]

-- | The keys, in ascending order. O(n).
keys :: BiMap k v -> [k]

-- | The values, ordered according to the corresponding keys. O(n).
elems :: BiMap k v -> [v]

-- | Conversion from two lists that contain distinct keys/tags, with the
--   keys/tags in ascending order. O(n).
--   
--   Precondition: See <a>fromDistinctAscendingListsPrecondition</a>.
fromDistinctAscendingLists :: ([(k, v)], [(Tag v, k)]) -> BiMap k v
fromDistinctAscendingListsPrecondition :: (Ord k, Eq v, Ord (Tag v), HasTag v) => ([(k, v)], [(Tag v, k)]) -> Bool

-- | Generates input suitable for <a>fromDistinctAscendingLists</a>. O(n).
toDistinctAscendingLists :: BiMap k v -> ([(k, v)], [(Tag v, k)])
instance GHC.Generics.Generic (Agda.Utils.BiMap.BiMap k v)
instance Agda.Utils.Null.Null (Agda.Utils.BiMap.BiMap k v)
instance (GHC.Classes.Eq k, GHC.Classes.Eq v) => GHC.Classes.Eq (Agda.Utils.BiMap.BiMap k v)
instance (GHC.Classes.Ord k, GHC.Classes.Ord v) => GHC.Classes.Ord (Agda.Utils.BiMap.BiMap k v)
instance (GHC.Show.Show k, GHC.Show.Show v) => GHC.Show.Show (Agda.Utils.BiMap.BiMap k v)

module Agda.Syntax.TopLevelModuleName.Boot
newtype ModuleNameHash
ModuleNameHash :: Word64 -> ModuleNameHash
[moduleNameHash] :: ModuleNameHash -> Word64
noModuleNameHash :: ModuleNameHash
type TopLevelModuleNameParts = List1 Text
data TopLevelModuleName' range
TopLevelModuleName :: range -> {-# UNPACK #-} !ModuleNameHash -> TopLevelModuleNameParts -> TopLevelModuleName' range
[moduleNameRange] :: TopLevelModuleName' range -> range
[moduleNameId] :: TopLevelModuleName' range -> {-# UNPACK #-} !ModuleNameHash
[moduleNameParts] :: TopLevelModuleName' range -> TopLevelModuleNameParts
instance Data.Hashable.Class.Hashable Agda.Syntax.TopLevelModuleName.Boot.ModuleNameHash
instance GHC.Classes.Ord Agda.Syntax.TopLevelModuleName.Boot.ModuleNameHash
instance GHC.Classes.Eq Agda.Syntax.TopLevelModuleName.Boot.ModuleNameHash
instance GHC.Generics.Generic (Agda.Syntax.TopLevelModuleName.Boot.TopLevelModuleName' range)
instance GHC.Show.Show range => GHC.Show.Show (Agda.Syntax.TopLevelModuleName.Boot.TopLevelModuleName' range)
instance Agda.Utils.BiMap.HasTag (Agda.Syntax.TopLevelModuleName.Boot.TopLevelModuleName' range)
instance GHC.Classes.Eq (Agda.Syntax.TopLevelModuleName.Boot.TopLevelModuleName' range)
instance GHC.Classes.Ord (Agda.Syntax.TopLevelModuleName.Boot.TopLevelModuleName' range)
instance Data.Hashable.Class.Hashable (Agda.Syntax.TopLevelModuleName.Boot.TopLevelModuleName' range)
instance Control.DeepSeq.NFData (Agda.Syntax.TopLevelModuleName.Boot.TopLevelModuleName' range)
instance Control.DeepSeq.NFData Agda.Syntax.TopLevelModuleName.Boot.ModuleNameHash
instance Agda.Utils.BiMap.HasTag Agda.Syntax.TopLevelModuleName.Boot.ModuleNameHash
instance GHC.Show.Show Agda.Syntax.TopLevelModuleName.Boot.ModuleNameHash


-- | Position information for syntax. Crucial for giving good error
--   messages.
module Agda.Syntax.Position
type Position = Position' SrcFile
type PositionWithoutFile = Position' ()

-- | Represents a point in the input.
--   
--   If two positions have the same <a>srcFile</a> and <a>posPos</a>
--   components, then the final two components should be the same as well,
--   but since this can be hard to enforce the program should not rely too
--   much on the last two components; they are mainly there to improve
--   error messages for the user.
--   
--   Note the invariant which positions have to satisfy:
--   <a>positionInvariant</a>.
data Position' a
Pn :: !a -> !Int32 -> !Int32 -> !Int32 -> Position' a

-- | File.
[srcFile] :: Position' a -> !a

-- | Position, counting from 1.
[posPos] :: Position' a -> !Int32

-- | Line number, counting from 1.
[posLine] :: Position' a -> !Int32

-- | Column number, counting from 1.
[posCol] :: Position' a -> !Int32
type SrcFile = Maybe RangeFile

-- | File information used in the <a>Position</a>, <a>Interval'</a> and
--   <a>Range'</a> types.
data RangeFile
RangeFile :: !AbsolutePath -> !Maybe (TopLevelModuleName' Range) -> RangeFile

-- | The file's path.
[rangeFilePath] :: RangeFile -> !AbsolutePath

-- | The file's top-level module name (if applicable).
--   
--   This field is optional, but some things may break if the field is not
--   instantiated with an actual top-level module name. For instance, the
--   <a>Eq</a> and <a>Ord</a> instances only make use of this field.
--   
--   The field uses <a>Maybe</a> rather than <a>Maybe</a> because it should
--   be possible to instantiate it with something that is not yet defined
--   (see <a>parseSource</a>).
--   
--   This '(TopLevelModuleName' Range)' should not contain a range.
[rangeFileName] :: RangeFile -> !Maybe (TopLevelModuleName' Range)

-- | A smart constructor for <a>RangeFile</a>.
mkRangeFile :: AbsolutePath -> Maybe (TopLevelModuleName' Range) -> RangeFile
positionInvariant :: Position' a -> Bool

-- | The first position in a file: position 1, line 1, column 1.
startPos :: Maybe RangeFile -> Position

-- | Advance the position by one character. A newline character
--   (<tt>'n'</tt>) moves the position to the first character in the next
--   line. Any other character moves the position to the next column.
movePos :: Position' a -> Char -> Position' a

-- | Advance the position by a string.
--   
--   <pre>
--   movePosByString = foldl' movePos
--   </pre>
movePosByString :: Foldable t => Position' a -> t Char -> Position' a

-- | Backup the position by one character.
--   
--   Precondition: The character must not be <tt>'n'</tt>.
backupPos :: Position' a -> Position' a

-- | The first position in a file: position 1, line 1, column 1.
startPos' :: a -> Position' a
type Interval = Interval' SrcFile
type IntervalWithoutFile = Interval' ()

-- | An interval. The <tt>iEnd</tt> position is not included in the
--   interval.
--   
--   Note the invariant which intervals have to satisfy:
--   <a>intervalInvariant</a>.
data Interval' a
Interval :: !Position' a -> Interval' a
[iStart, iEnd] :: Interval' a -> !Position' a
intervalInvariant :: Ord a => Interval' a -> Bool

-- | Converts a file name and two positions to an interval.
posToInterval :: a -> PositionWithoutFile -> PositionWithoutFile -> Interval' a

-- | Gets the <a>srcFile</a> component of the interval. Because of the
--   invariant, they are both the same.
getIntervalFile :: Interval' a -> a

-- | The length of an interval.
iLength :: Interval' a -> Int32

-- | Finds the least interval which covers the arguments.
--   
--   Precondition: The intervals must point to the same file.
fuseIntervals :: Ord a => Interval' a -> Interval' a -> Interval' a

-- | Sets the <a>srcFile</a> components of the interval.
setIntervalFile :: a -> Interval' b -> Interval' a
type Range = Range' SrcFile

-- | A range is a file name, plus a sequence of intervals, assumed to point
--   to the given file. The intervals should be consecutive and separated.
--   
--   Note the invariant which ranges have to satisfy:
--   <a>rangeInvariant</a>.
data Range' a
NoRange :: Range' a
Range :: !a -> Seq IntervalWithoutFile -> Range' a

-- | Range invariant.
rangeInvariant :: Ord a => Range' a -> Bool

-- | Are the intervals consecutive and separated, do they all point to the
--   same file, and do they satisfy the interval invariant?
consecutiveAndSeparated :: Ord a => [Interval' a] -> Bool

-- | Turns a file name plus a list of intervals into a range.
--   
--   Precondition: <a>consecutiveAndSeparated</a>.
intervalsToRange :: a -> [IntervalWithoutFile] -> Range' a

-- | Converts a file name and an interval to a range.
intervalToRange :: a -> IntervalWithoutFile -> Range' a

-- | The intervals that make up the range. The intervals are consecutive
--   and separated (<a>consecutiveAndSeparated</a>).
rangeIntervals :: Range' a -> [IntervalWithoutFile]

-- | The file the range is pointing to.
rangeFile :: Range -> SrcFile

-- | The range's top-level module name, if any.
--   
--   If there is no range, then <a>Nothing</a> is returned. If there is a
--   range without a module name, then <tt><a>Just</a> <a>Nothing</a></tt>
--   is returned.
rangeModule' :: Range -> Maybe (Maybe (TopLevelModuleName' Range))

-- | The range's top-level module name, if any.
rangeModule :: Range -> Maybe (TopLevelModuleName' Range)

-- | Conflate a range to its right margin.
rightMargin :: Range -> Range

-- | Ranges between two unknown positions
noRange :: Range' a

-- | Converts two positions to a range.
--   
--   Precondition: The positions have to point to the same file.
posToRange :: Position' a -> Position' a -> Range' a

-- | Converts a file name and two positions to a range.
posToRange' :: a -> PositionWithoutFile -> PositionWithoutFile -> Range' a

-- | The initial position in the range, if any.
rStart :: Range' a -> Maybe (Position' a)

-- | The initial position in the range, if any.
rStart' :: Range' a -> Maybe PositionWithoutFile

-- | The position after the final position in the range, if any.
rEnd :: Range' a -> Maybe (Position' a)

-- | The position after the final position in the range, if any.
rEnd' :: Range' a -> Maybe PositionWithoutFile

-- | Converts a range to an interval, if possible. Note that the
--   information about the source file is lost.
rangeToInterval :: Range' a -> Maybe IntervalWithoutFile

-- | Converts a range to an interval, if possible.
rangeToIntervalWithFile :: Range' a -> Maybe (Interval' a)

-- | Returns the shortest continuous range containing the given one.
continuous :: Range' a -> Range' a

-- | Removes gaps between intervals on the same line.
continuousPerLine :: Ord a => Range' a -> Range' a

-- | Wrapper to indicate that range should be printed.
newtype PrintRange a
PrintRange :: a -> PrintRange a

-- | Things that have a range are instances of this class.
class HasRange a
getRange :: HasRange a => a -> Range
getRange :: (HasRange a, Foldable t, HasRange b, t b ~ a) => a -> Range

-- | If it is also possible to set the range, this is the class.
--   
--   Instances should satisfy <tt><a>getRange</a> (<a>setRange</a> r x) ==
--   r</tt>.
class HasRange a => SetRange a
setRange :: SetRange a => Range -> a -> a
setRange :: (SetRange a, Functor f, SetRange b, f b ~ a) => Range -> a -> a

-- | Killing the range of an object sets all range information to
--   <a>noRange</a>.
class KillRange a
killRange :: KillRange a => KillRangeT a
killRange :: (KillRange a, Functor f, KillRange b, f b ~ a) => KillRangeT a
type KillRangeT a = a -> a

-- | Remove ranges in keys and values of a map.
killRangeMap :: (KillRange k, KillRange v) => KillRangeT (Map k v)
class KILLRANGE t b
killRangeN :: (KILLRANGE t b, IsBase t ~ b) => All KillRange (Domains t) => t -> t

-- | <tt>x `withRangeOf` y</tt> sets the range of <tt>x</tt> to the range
--   of <tt>y</tt>.
withRangeOf :: (SetRange t, HasRange u) => t -> u -> t

-- | Precondition: The ranges must point to the same file (or be empty).
fuseRange :: (HasRange u, HasRange t) => u -> t -> Range

-- | <tt>fuseRanges r r'</tt> unions the ranges <tt>r</tt> and <tt>r'</tt>.
--   
--   Meaning it finds the least range <tt>r0</tt> that covers <tt>r</tt>
--   and <tt>r'</tt>.
--   
--   Precondition: The ranges must point to the same file (or be empty).
fuseRanges :: Ord a => Range' a -> Range' a -> Range' a

-- | <tt>beginningOf r</tt> is an empty range (a single, empty interval)
--   positioned at the beginning of <tt>r</tt>. If <tt>r</tt> does not have
--   a beginning, then <a>noRange</a> is returned.
beginningOf :: Range -> Range

-- | <tt>beginningOfFile r</tt> is an empty range (a single, empty
--   interval) at the beginning of <tt>r</tt>'s starting position's file.
--   If there is no such position, then an empty range is returned.
beginningOfFile :: Range -> Range

-- | Interleaves two streams of ranged elements
--   
--   It will report the conflicts as a list of conflicting pairs. In case
--   of conflict, the element with the earliest start position is placed
--   first. In case of a tie, the element with the earliest ending position
--   is placed first. If both tie, the element from the first list is
--   placed first.
interleaveRanges :: HasRange a => [a] -> [a] -> ([a], [(a, a)])
instance GHC.Generics.Generic (Agda.Syntax.Position.Position' a)
instance Data.Traversable.Traversable Agda.Syntax.Position.Position'
instance Data.Foldable.Foldable Agda.Syntax.Position.Position'
instance GHC.Base.Functor Agda.Syntax.Position.Position'
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Position.Position' a)
instance GHC.Generics.Generic (Agda.Syntax.Position.Interval' a)
instance Data.Traversable.Traversable Agda.Syntax.Position.Interval'
instance Data.Foldable.Foldable Agda.Syntax.Position.Interval'
instance GHC.Base.Functor Agda.Syntax.Position.Interval'
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.Syntax.Position.Interval' a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Position.Interval' a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Position.Interval' a)
instance GHC.Generics.Generic (Agda.Syntax.Position.Range' a)
instance Data.Traversable.Traversable Agda.Syntax.Position.Range'
instance Data.Foldable.Foldable Agda.Syntax.Position.Range'
instance GHC.Base.Functor Agda.Syntax.Position.Range'
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.Syntax.Position.Range' a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Position.Range' a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Position.Range' a)
instance GHC.Generics.Generic Agda.Syntax.Position.RangeFile
instance GHC.Show.Show Agda.Syntax.Position.RangeFile
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Syntax.Position.PrintRange a)
instance Agda.Syntax.Position.SetRange a => Agda.Syntax.Position.SetRange (Agda.Syntax.Position.PrintRange a)
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange (Agda.Syntax.Position.PrintRange a)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.Syntax.Position.PrintRange a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Position.PrintRange a)
instance (Agda.Utils.TypeLevel.IsBase t GHC.Types.~ 'GHC.Types.True) => Agda.Syntax.Position.KILLRANGE t 'GHC.Types.True
instance Agda.Syntax.Position.KILLRANGE t (Agda.Utils.TypeLevel.IsBase t) => Agda.Syntax.Position.KILLRANGE (a -> t) 'GHC.Types.False
instance (Agda.Syntax.Position.KillRange a, Agda.Syntax.Position.KillRange b, Agda.Syntax.Position.KillRange c) => Agda.Syntax.Position.KillRange (a, b, c)
instance (Agda.Syntax.Position.KillRange a, Agda.Syntax.Position.KillRange b, Agda.Syntax.Position.KillRange c, Agda.Syntax.Position.KillRange d) => Agda.Syntax.Position.KillRange (a, b, c, d)
instance Agda.Syntax.Position.KillRange (Agda.Syntax.TopLevelModuleName.Boot.TopLevelModuleName' Agda.Syntax.Position.Range)
instance Agda.Syntax.Position.KillRange Agda.Syntax.Position.Range
instance Agda.Syntax.Position.KillRange GHC.Base.Void
instance Agda.Syntax.Position.KillRange ()
instance Agda.Syntax.Position.KillRange GHC.Types.Bool
instance Agda.Syntax.Position.KillRange GHC.Types.Int
instance Agda.Syntax.Position.KillRange GHC.Num.Integer.Integer
instance Agda.Syntax.Position.KillRange Agda.Utils.Permutation.Permutation
instance Agda.Syntax.Position.KillRange GHC.Base.String
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange [a]
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Data.Map.Internal.Map k a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Utils.Permutation.Drop a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Utils.List1.List1 a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Utils.List2.List2 a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (GHC.Maybe.Maybe a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Data.Strict.Maybe.Maybe a)
instance (GHC.Classes.Ord a, Agda.Syntax.Position.KillRange a) => Agda.Syntax.Position.KillRange (Data.Set.Internal.Set a)
instance (Agda.Syntax.Position.KillRange a, Agda.Syntax.Position.KillRange b) => Agda.Syntax.Position.KillRange (a, b)
instance (Agda.Syntax.Position.KillRange a, Agda.Syntax.Position.KillRange b) => Agda.Syntax.Position.KillRange (Data.Either.Either a b)
instance Agda.Syntax.Position.SetRange (Agda.Syntax.TopLevelModuleName.Boot.TopLevelModuleName' Agda.Syntax.Position.Range)
instance Agda.Syntax.Position.SetRange Agda.Syntax.Position.Range
instance Agda.Syntax.Position.SetRange a => Agda.Syntax.Position.SetRange [a]
instance Agda.Syntax.Position.SetRange a => Agda.Syntax.Position.SetRange (GHC.Maybe.Maybe a)
instance Agda.Syntax.Position.HasRange Agda.Syntax.Position.Interval
instance Agda.Syntax.Position.HasRange Agda.Syntax.Position.Range
instance Agda.Syntax.Position.HasRange ()
instance Agda.Syntax.Position.HasRange GHC.Types.Bool
instance Agda.Syntax.Position.HasRange (Agda.Syntax.TopLevelModuleName.Boot.TopLevelModuleName' Agda.Syntax.Position.Range)
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange [a]
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange (Agda.Utils.List1.List1 a)
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange (Agda.Utils.List2.List2 a)
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange (GHC.Maybe.Maybe a)
instance (Agda.Syntax.Position.HasRange a, Agda.Syntax.Position.HasRange b) => Agda.Syntax.Position.HasRange (a, b)
instance (Agda.Syntax.Position.HasRange a, Agda.Syntax.Position.HasRange b, Agda.Syntax.Position.HasRange c) => Agda.Syntax.Position.HasRange (a, b, c)
instance (Agda.Syntax.Position.HasRange a, Agda.Syntax.Position.HasRange b, Agda.Syntax.Position.HasRange c, Agda.Syntax.Position.HasRange d) => Agda.Syntax.Position.HasRange (a, b, c, d)
instance (Agda.Syntax.Position.HasRange a, Agda.Syntax.Position.HasRange b, Agda.Syntax.Position.HasRange c, Agda.Syntax.Position.HasRange d, Agda.Syntax.Position.HasRange e) => Agda.Syntax.Position.HasRange (a, b, c, d, e)
instance (Agda.Syntax.Position.HasRange a, Agda.Syntax.Position.HasRange b, Agda.Syntax.Position.HasRange c, Agda.Syntax.Position.HasRange d, Agda.Syntax.Position.HasRange e, Agda.Syntax.Position.HasRange f) => Agda.Syntax.Position.HasRange (a, b, c, d, e, f)
instance (Agda.Syntax.Position.HasRange a, Agda.Syntax.Position.HasRange b, Agda.Syntax.Position.HasRange c, Agda.Syntax.Position.HasRange d, Agda.Syntax.Position.HasRange e, Agda.Syntax.Position.HasRange f, Agda.Syntax.Position.HasRange g) => Agda.Syntax.Position.HasRange (a, b, c, d, e, f, g)
instance (Agda.Syntax.Position.HasRange a, Agda.Syntax.Position.HasRange b) => Agda.Syntax.Position.HasRange (Data.Either.Either a b)
instance Control.DeepSeq.NFData Agda.Syntax.Position.Position
instance Control.DeepSeq.NFData Agda.Syntax.Position.Interval
instance GHC.Classes.Eq Agda.Syntax.Position.RangeFile
instance GHC.Classes.Ord Agda.Syntax.Position.RangeFile
instance Control.DeepSeq.NFData Agda.Syntax.Position.RangeFile
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Position.Range' a)
instance Agda.Utils.Null.Null (Agda.Syntax.Position.Range' a)
instance GHC.Classes.Eq a => GHC.Base.Semigroup (Agda.Syntax.Position.Range' a)
instance GHC.Classes.Eq a => GHC.Base.Monoid (Agda.Syntax.Position.Range' a)
instance Control.DeepSeq.NFData Agda.Syntax.Position.IntervalWithoutFile
instance Control.DeepSeq.NFData Agda.Syntax.Position.PositionWithoutFile
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Position.Position' a)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.Syntax.Position.Position' a)

module Agda.Syntax.Common.Aspect
data Induction
Inductive :: Induction
CoInductive :: Induction
data Aspect
Comment :: Aspect
Keyword :: Aspect
String :: Aspect
Number :: Aspect
Hole :: Aspect

-- | Symbols like forall, =, -&gt;, etc.
Symbol :: Aspect

-- | Things like Set and Prop.
PrimitiveType :: Aspect

-- | Is the name an operator part?
Name :: Maybe NameKind -> Bool -> Aspect

-- | Text occurring in pragmas that does not have a more specific aspect.
Pragma :: Aspect

-- | Non-code contents in literate Agda
Background :: Aspect

-- | Delimiters used to separate the Agda code blocks from the other
--   contents in literate Agda
Markup :: Aspect

-- | <tt>NameKind</tt>s are figured out during scope checking.
data NameKind

-- | Bound variable.
Bound :: NameKind

-- | Generalizable variable. (This includes generalizable variables that
--   have been generalized).
Generalizable :: NameKind

-- | Inductive or coinductive constructor.
Constructor :: Induction -> NameKind
Datatype :: NameKind

-- | Record field.
Field :: NameKind
Function :: NameKind

-- | Module name.
Module :: NameKind
Postulate :: NameKind

-- | Primitive.
Primitive :: NameKind

-- | Record type.
Record :: NameKind

-- | Named argument, like x in {x = v}
Argument :: NameKind

-- | Macro.
Macro :: NameKind

-- | Other aspects, generated by type checking. (These can overlap with
--   each other and with <a>Aspect</a>s.)
data OtherAspect
Error :: OtherAspect

-- | A warning that is considered fatal in the end.
ErrorWarning :: OtherAspect
DottedPattern :: OtherAspect
UnsolvedMeta :: OtherAspect

-- | Unsolved constraint not connected to meta-variable. This could for
--   instance be an emptyness constraint.
UnsolvedConstraint :: OtherAspect
TerminationProblem :: OtherAspect
PositivityProblem :: OtherAspect

-- | Used for highlighting unreachable clauses, unreachable RHS (because of
--   an absurd pattern), etc.
Deadcode :: OtherAspect

-- | Used for shadowed repeated variable names in telescopes.
ShadowingInTelescope :: OtherAspect
CoverageProblem :: OtherAspect

-- | When this constructor is used it is probably a good idea to include a
--   <a>note</a> explaining why the pattern is incomplete.
IncompletePattern :: OtherAspect

-- | Code which is being type-checked.
TypeChecks :: OtherAspect

-- | Function declaration without matching definition NB: We put
--   CatchallClause last so that it is overwritten by other, more
--   important, aspects in the emacs mode.
MissingDefinition :: OtherAspect
CatchallClause :: OtherAspect
ConfluenceProblem :: OtherAspect

-- | Syntactic aspects of the code. (These cannot overlap.)
--   
--   Meta information which can be associated with a character/character
--   range.
data Aspects
Aspects :: Maybe Aspect -> Set OtherAspect -> String -> Maybe DefinitionSite -> !TokenBased -> Aspects
[aspect] :: Aspects -> Maybe Aspect
[otherAspects] :: Aspects -> Set OtherAspect

-- | This note, if not null, can be displayed as a tool-tip or something
--   like that. It should contain useful information about the range (like
--   the module containing a certain identifier, or the fixity of an
--   operator).
[note] :: Aspects -> String

-- | The definition site of the annotated thing, if applicable and known.
[definitionSite] :: Aspects -> Maybe DefinitionSite

-- | Is this entry token-based?
[tokenBased] :: Aspects -> !TokenBased
data DefinitionSite
DefinitionSite :: TopLevelModuleName' Range -> Int -> Bool -> Maybe String -> DefinitionSite

-- | The defining module.
[defSiteModule] :: DefinitionSite -> TopLevelModuleName' Range

-- | The file position in that module. File positions are counted from 1.
[defSitePos] :: DefinitionSite -> Int

-- | Has this <tt>DefinitionSite</tt> been created at the defining site of
--   the name?
[defSiteHere] :: DefinitionSite -> Bool

-- | A pretty name for the HTML linking.
[defSiteAnchor] :: DefinitionSite -> Maybe String

-- | Is the highlighting "token-based", i.e. based only on information from
--   the lexer?
data TokenBased
TokenBased :: TokenBased
NotOnlyTokenBased :: TokenBased
instance GHC.Show.Show Agda.Syntax.Common.Aspect.Induction
instance GHC.Classes.Ord Agda.Syntax.Common.Aspect.Induction
instance GHC.Classes.Eq Agda.Syntax.Common.Aspect.Induction
instance GHC.Generics.Generic Agda.Syntax.Common.Aspect.NameKind
instance GHC.Show.Show Agda.Syntax.Common.Aspect.NameKind
instance GHC.Classes.Eq Agda.Syntax.Common.Aspect.NameKind
instance GHC.Generics.Generic Agda.Syntax.Common.Aspect.Aspect
instance GHC.Show.Show Agda.Syntax.Common.Aspect.Aspect
instance GHC.Classes.Eq Agda.Syntax.Common.Aspect.Aspect
instance GHC.Generics.Generic Agda.Syntax.Common.Aspect.OtherAspect
instance GHC.Enum.Bounded Agda.Syntax.Common.Aspect.OtherAspect
instance GHC.Enum.Enum Agda.Syntax.Common.Aspect.OtherAspect
instance GHC.Show.Show Agda.Syntax.Common.Aspect.OtherAspect
instance GHC.Classes.Ord Agda.Syntax.Common.Aspect.OtherAspect
instance GHC.Classes.Eq Agda.Syntax.Common.Aspect.OtherAspect
instance GHC.Generics.Generic Agda.Syntax.Common.Aspect.DefinitionSite
instance GHC.Show.Show Agda.Syntax.Common.Aspect.DefinitionSite
instance GHC.Show.Show Agda.Syntax.Common.Aspect.TokenBased
instance GHC.Classes.Eq Agda.Syntax.Common.Aspect.TokenBased
instance GHC.Generics.Generic Agda.Syntax.Common.Aspect.Aspects
instance GHC.Show.Show Agda.Syntax.Common.Aspect.Aspects
instance GHC.Classes.Eq Agda.Syntax.Common.Aspect.Aspects
instance GHC.Classes.Eq Agda.Syntax.Common.Aspect.DefinitionSite
instance GHC.Base.Semigroup Agda.Syntax.Common.Aspect.Aspect
instance GHC.Base.Semigroup Agda.Syntax.Common.Aspect.NameKind
instance Control.DeepSeq.NFData Agda.Syntax.Common.Aspect.NameKind
instance Control.DeepSeq.NFData Agda.Syntax.Common.Aspect.Induction


-- | Pretty printing functions.
module Agda.Syntax.Common.Pretty

-- | The type of documents. We use documents annotated by <a>Aspects</a> to
--   record syntactic highlighting information that is generated during
--   pretty-printing.
type Doc = Doc Aspects

-- | While <a>Show</a> is for rendering data in Haskell syntax,
--   <a>Pretty</a> is for displaying data to the world, i.e., the user and
--   the environment.
--   
--   Atomic data has no inner document structure, so just implement
--   <a>pretty</a> as <tt>pretty a = text $ ... a ...</tt>.
class Pretty a
pretty :: Pretty a => a -> Doc
prettyPrec :: Pretty a => Int -> a -> Doc
prettyList :: Pretty a => [a] -> Doc

-- | <pre>
--   a <a>?</a> b = hang a 2 b
--   </pre>
(<?>) :: Doc -> Doc -> Doc
infixl 6 <?>
comma :: Doc
colon :: Doc
parens :: Doc -> Doc

-- | <tt>align max rows</tt> lays out the elements of <tt>rows</tt> in two
--   columns, with the second components aligned. The alignment column of
--   the second components is at most <tt>max</tt> characters to the right
--   of the left-most column.
--   
--   Precondition: <tt>max &gt; 0</tt>.
align :: Int -> [(String, Doc)] -> Doc
hcat :: Foldable t => t Doc -> Doc
hsep :: Foldable t => t Doc -> Doc
vcat :: Foldable t => t Doc -> Doc
vsep :: [Doc] -> Doc
space :: Doc
braces :: Doc -> Doc
brackets :: Doc -> Doc
semi :: Doc
equals :: Doc
lparen :: Doc
rparen :: Doc
lbrack :: Doc
rbrack :: Doc
lbrace :: Doc
rbrace :: Doc
quotes :: Doc -> Doc
doubleQuotes :: Doc -> Doc
punctuate :: Foldable t => Doc -> t Doc -> [Doc]
sep :: Foldable t => t Doc -> Doc
fsep :: Foldable t => t Doc -> Doc

-- | Use instead of <a>show</a> when printing to world.
prettyShow :: Pretty a => a -> String

-- | Comma separated list, without the brackets.
prettyList_ :: Pretty a => [a] -> Doc
singPlural :: Sized a => a -> c -> c -> c

-- | <pre>
--   pshow = text . show
--   </pre>
pshow :: Show a => a -> Doc

-- | Pretty print a set.
prettySet :: Pretty a => [a] -> Doc

-- | Pretty print an association list.
prettyMap :: (Pretty k, Pretty v) => [(k, v)] -> Doc
pwords :: String -> [Doc]
fwords :: String -> Doc

-- | Separate, but only if both separees are not null.
hsepWith :: Doc -> Doc -> Doc -> Doc

-- | Pretty print a single association.
prettyAssign :: (Pretty k, Pretty v) => (k, v) -> Doc
hlSymbol :: Doc -> Doc

-- | Apply <a>parens</a> to <a>Doc</a> if boolean is true.
mparens :: Bool -> Doc -> Doc

-- | Only wrap in parens if not <a>empty</a>
parensNonEmpty :: Doc -> Doc

-- | Handles strings with newlines properly (preserving indentation)
multiLineText :: String -> Doc

-- | Used for with-like <tt>telescopes</tt>
prefixedThings :: Doc -> [Doc] -> Doc

-- | Attach a simple <a>Aspect</a>, rather than a full set of
--   <a>Aspects</a>, to a document.
annotateAspect :: Aspect -> Doc -> Doc
hlComment :: Doc -> Doc
hlKeyword :: Doc -> Doc
hlString :: Doc -> Doc
hlNumber :: Doc -> Doc
hlHole :: Doc -> Doc
hlPrimitiveType :: Doc -> Doc
hlPragma :: Doc -> Doc

-- | Rendering mode.
data () => Mode

-- | Normal rendering (<a>lineLength</a> and <a>ribbonsPerLine</a>
--   respected').
PageMode :: Mode

-- | With zig-zag cuts.
ZigZagMode :: Mode

-- | No indentation, infinitely long lines (<a>lineLength</a> ignored), but
--   explicit new lines, i.e., <tt>text "one" $$ text "two"</tt>, are
--   respected.
LeftMode :: Mode

-- | All on one line, <a>lineLength</a> ignored and explicit new lines
--   (<tt>$$</tt>) are turned into spaces.
OneLineMode :: Mode

-- | A <tt>Span</tt> represents the result of an annotation after a
--   <tt>Doc</tt> has been rendered, capturing where the annotation now
--   starts and ends in the rendered output.
data () => Span a
Span :: !Int -> !Int -> a -> Span a
[spanStart] :: Span a -> !Int
[spanLength] :: Span a -> !Int
[spanAnnotation] :: Span a -> a

-- | 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 <i>excluding</i> indentation. So a
--   <a>lineLength</a> of 100, with a <a>ribbonsPerLine</a> of <tt>2.0</tt>
--   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

-- | A single Char fragment
pattern Chr :: () => {-# UNPACK #-} !Char -> TextDetails

-- | Used to represent a Fast String fragment but now deprecated and
--   identical to the Str constructor.
pattern PStr :: () => String -> TextDetails

-- | A document of height 1 containing a literal string. <a>text</a>
--   satisfies the following laws:
--   
--   <ul>
--   <li><pre><a>text</a> s <a>&lt;&gt;</a> <a>text</a> t = <a>text</a>
--   (s<a>++</a>t)</pre></li>
--   <li><tt><a>text</a> "" <a>&lt;&gt;</a> x = x</tt>, if <tt>x</tt>
--   non-empty</li>
--   </ul>
--   
--   The side condition on the last law is necessary because
--   <tt><a>text</a> ""</tt> has height 1, while <a>empty</a> has no
--   height.
text :: String -> Doc a
int :: Int -> Doc a
integer :: Integer -> Doc a
float :: Float -> Doc a
double :: Double -> Doc a

-- | A document of height and width 1, containing a literal character.
char :: Char -> Doc a

-- | Beside, separated by space, unless one of the arguments is
--   <a>empty</a>. <a>&lt;+&gt;</a> is associative, with identity
--   <a>empty</a>.
(<+>) :: Doc a -> Doc a -> Doc a
infixl 6 <+>

-- | Returns <a>True</a> if the document is empty
isEmpty :: Doc a -> Bool

-- | The default style (<tt>mode=PageMode, lineLength=100,
--   ribbonsPerLine=1.5</tt>).
style :: Style

-- | Render the <tt>Doc</tt> to a String using the default <tt>Style</tt>
--   (see <a>style</a>).
render :: Doc a -> String

-- | Attach an annotation to a document.
annotate :: a -> Doc a -> Doc a

-- | Same as <tt>text</tt>. Used to be used for Bytestrings.
ptext :: String -> Doc a

-- | Some text with any width. (<tt>text s = sizedText (length s) s</tt>)
sizedText :: Int -> String -> Doc a

-- | Some text, but without any width. Use for non-printing text such as a
--   HTML or Latex tags
zeroWidthText :: String -> Doc a
rational :: Rational -> Doc a

-- | Nest (or indent) a document by a given number of positions (which may
--   also be negative). <a>nest</a> satisfies the laws:
--   
--   <ul>
--   <li><pre><a>nest</a> 0 x = x</pre></li>
--   <li><pre><a>nest</a> k (<a>nest</a> k' x) = <a>nest</a> (k+k')
--   x</pre></li>
--   <li><pre><a>nest</a> k (x <a>&lt;&gt;</a> y) = <a>nest</a> k z
--   <a>&lt;&gt;</a> <a>nest</a> k y</pre></li>
--   <li><pre><a>nest</a> k (x <a>$$</a> y) = <a>nest</a> k x <a>$$</a>
--   <a>nest</a> k y</pre></li>
--   <li><pre><a>nest</a> k <a>empty</a> = <a>empty</a></pre></li>
--   <li><tt>x <a>&lt;&gt;</a> <a>nest</a> k y = x <a>&lt;&gt;</a> y</tt>,
--   if <tt>x</tt> non-empty</li>
--   </ul>
--   
--   The side condition on the last law is needed because <a>empty</a> is a
--   left identity for <a>&lt;&gt;</a>.
nest :: Int -> Doc a -> Doc a

-- | <pre>
--   hang d1 n d2 = sep [d1, nest n d2]
--   </pre>
hang :: Doc a -> Int -> Doc a -> Doc a

-- | Above, except that if the last line of the first argument stops at
--   least one position before the first line of the second begins, these
--   two lines are overlapped. For example:
--   
--   <pre>
--   text "hi" $$ nest 5 (text "there")
--   </pre>
--   
--   lays out as
--   
--   <pre>
--   hi   there
--   </pre>
--   
--   rather than
--   
--   <pre>
--   hi
--        there
--   </pre>
--   
--   <a>$$</a> is associative, with identity <a>empty</a>, and also
--   satisfies
--   
--   <ul>
--   <li><tt>(x <a>$$</a> y) <a>&lt;&gt;</a> z = x <a>$$</a> (y
--   <a>&lt;&gt;</a> z)</tt>, if <tt>y</tt> non-empty.</li>
--   </ul>
($$) :: Doc a -> Doc a -> Doc a
infixl 5 $$

-- | Above, with no overlapping. <a>$+$</a> is associative, with identity
--   <a>empty</a>.
($+$) :: Doc a -> Doc a -> Doc a
infixl 5 $+$

-- | Either <a>hcat</a> or <a>vcat</a>.
cat :: [Doc a] -> Doc a

-- | "Paragraph fill" version of <a>cat</a>.
fcat :: [Doc a] -> Doc a

-- | Render the <tt>Doc</tt> to a String using the given <tt>Style</tt>.
renderStyle :: Style -> Doc a -> String

-- | The general rendering interface. Please refer to the <tt>Style</tt>
--   and <tt>Mode</tt> types for a description of rendering mode, line
--   length and ribbons.
fullRender :: Mode -> Int -> Float -> (TextDetails -> a -> a) -> a -> Doc b -> a

-- | The general rendering interface, supporting annotations. Please refer
--   to the <tt>Style</tt> and <tt>Mode</tt> types for a description of
--   rendering mode, line length and ribbons.
fullRenderAnn :: Mode -> Int -> Float -> (AnnotDetails b -> a -> a) -> a -> Doc b -> a

-- | Render an annotated <tt>Doc</tt> to a String and list of annotations
--   (see <a>Span</a>) using the default <tt>Style</tt> (see <a>style</a>).
renderSpans :: Doc ann -> (String, [Span ann])

-- | An associative operation.
--   
--   <pre>
--   &gt;&gt;&gt; [1,2,3] &lt;&gt; [4,5,6]
--   [1,2,3,4,5,6]
--   </pre>
(<>) :: Semigroup a => a -> a -> a
infixr 6 <>
instance Agda.Syntax.Common.Pretty.Pretty GHC.Types.Bool
instance Agda.Syntax.Common.Pretty.Pretty GHC.Types.Int
instance Agda.Syntax.Common.Pretty.Pretty GHC.Int.Int32
instance Agda.Syntax.Common.Pretty.Pretty GHC.Num.Integer.Integer
instance Agda.Syntax.Common.Pretty.Pretty GHC.Word.Word64
instance Agda.Syntax.Common.Pretty.Pretty GHC.Types.Double
instance Agda.Syntax.Common.Pretty.Pretty Data.Text.Internal.Text
instance Agda.Syntax.Common.Pretty.Pretty GHC.Types.Char
instance (a GHC.Types.~ Agda.Syntax.Common.Aspect.Aspects) => Agda.Syntax.Common.Pretty.Pretty (Text.PrettyPrint.Annotated.HughesPJ.Doc a)
instance Agda.Syntax.Common.Pretty.Pretty ()
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (GHC.Maybe.Maybe a)
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty [a]
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Utils.List1.List1 a)
instance Agda.Syntax.Common.Pretty.Pretty Data.IntSet.Internal.IntSet
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Data.Set.Internal.Set a)
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Data.IntMap.Internal.IntMap a)
instance (Agda.Syntax.Common.Pretty.Pretty k, Agda.Syntax.Common.Pretty.Pretty v) => Agda.Syntax.Common.Pretty.Pretty (Data.Map.Internal.Map k v)
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.FileName.AbsolutePath
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Position.RangeFile
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Position.Position' (Data.Strict.Maybe.Maybe a))
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Position.PositionWithoutFile
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Position.IntervalWithoutFile
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Position.Interval' (Data.Strict.Maybe.Maybe a))
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Position.Range' (Data.Strict.Maybe.Maybe a))
instance (Agda.Syntax.Common.Pretty.Pretty a, Agda.Syntax.Position.HasRange a) => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Position.PrintRange a)


-- | Time-related utilities.
module Agda.Utils.Time

-- | Timestamps.
type ClockTime = UTCTime

-- | The current time.
getClockTime :: IO ClockTime
getCPUTime :: MonadIO m => m CPUTime

-- | Measure the time of a computation. Of course, does not work with
--   exceptions.
measureTime :: MonadIO m => m a -> m (a, CPUTime)

-- | CPU time in pico (10^-12) seconds.
newtype CPUTime
CPUTime :: Integer -> CPUTime
fromMilliseconds :: Integer -> CPUTime
instance Control.DeepSeq.NFData Agda.Utils.Time.CPUTime
instance GHC.Real.Integral Agda.Utils.Time.CPUTime
instance GHC.Enum.Enum Agda.Utils.Time.CPUTime
instance GHC.Real.Real Agda.Utils.Time.CPUTime
instance GHC.Num.Num Agda.Utils.Time.CPUTime
instance GHC.Classes.Ord Agda.Utils.Time.CPUTime
instance GHC.Show.Show Agda.Utils.Time.CPUTime
instance GHC.Classes.Eq Agda.Utils.Time.CPUTime
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Time.CPUTime


-- | Parser combinators with support for left recursion, following
--   Johnson's "Memoization in Top-Down Parsing".
--   
--   This implementation is based on an implementation due to Atkey
--   (attached to an edlambda-members mailing list message from 2011-02-15
--   titled 'Slides for "Introduction to Parser Combinators"').
--   
--   Note that non-memoised left recursion is not guaranteed to work.
--   
--   The code contains an important deviation from Johnson's paper: the
--   check for subsumed results is not included. This means that one can
--   get the same result multiple times when parsing using ambiguous
--   grammars. As an example, parsing the empty string using <tt>S ∷= ε |
--   ε</tt> succeeds twice. This change also means that parsing fails to
--   terminate for some cyclic grammars that would otherwise be handled
--   successfully, such as <tt>S ∷= S | ε</tt>. However, the library is not
--   intended to handle infinitely ambiguous grammars. (It is unclear to
--   the author of this module whether the change leads to more
--   non-termination for grammars that are not cyclic.)
module Agda.Utils.Parser.MemoisedCPS
class (Functor p, Applicative p, Alternative p, Monad p) => ParserClass p k r tok | p -> k, p -> r, p -> tok

-- | Runs the parser.
parse :: ParserClass p k r tok => p a -> [tok] -> [a]

-- | Tries to print the parser, or returns <a>empty</a>, depending on the
--   implementation. This function might not terminate.
grammar :: (ParserClass p k r tok, Show k) => p a -> Doc

-- | Parses a token satisfying the given predicate. The computed value is
--   returned.
sat' :: ParserClass p k r tok => (tok -> Maybe a) -> p a

-- | Uses the given function to modify the printed representation (if any)
--   of the given parser.
annotate :: ParserClass p k r tok => (DocP -> DocP) -> p a -> p a

-- | Memoises the given parser.
--   
--   Every memoised parser must be annotated with a <i>unique</i> key.
--   (Parametrised parsers must use distinct keys for distinct inputs.)
memoise :: (ParserClass p k r tok, Eq k, Hashable k, Show k) => k -> p r -> p r

-- | Memoises the given parser, but only if printing, not if parsing.
--   
--   Every memoised parser must be annotated with a <i>unique</i> key.
--   (Parametrised parsers must use distinct keys for distinct inputs.)
memoiseIfPrinting :: (ParserClass p k r tok, Eq k, Hashable k, Show k) => k -> p r -> p r

-- | Parses a token satisfying the given predicate.
sat :: ParserClass p k r tok => (tok -> Bool) -> p tok

-- | Parses a single token.
token :: ParserClass p k r tok => p tok

-- | Parses a given token.
tok :: (ParserClass p k r tok, Eq tok, Show tok) => tok -> p tok

-- | Uses the given document as the printed representation of the given
--   parser. The document's precedence is taken to be <a>atomP</a>.
doc :: ParserClass p k r tok => Doc -> p a -> p a

-- | Documents paired with precedence levels.
type DocP = (Doc, Int)

-- | Precedence of <tt>&gt;&gt;=</tt>.
bindP :: Int

-- | Precedence of <tt><a>|</a></tt>.
choiceP :: Int

-- | Precedence of <tt><a>*</a></tt>.
seqP :: Int

-- | Precedence of <tt>⋆</tt> and <tt>+</tt>.
starP :: Int

-- | Precedence of atoms.
atomP :: Int

-- | The parser type.
--   
--   The parameters of the type <tt>Parser k r tok a</tt> have the
--   following meanings:
--   
--   <ul>
--   <li><i><tt>k</tt></i> Type used for memoisation keys.</li>
--   <li><i><tt>r</tt></i> The type of memoised values. (Yes, all memoised
--   values have to have the same type.)</li>
--   <li><i><tt>tok</tt></i> The token type.</li>
--   <li><i><tt>a</tt></i> The result type.</li>
--   </ul>
data Parser k r tok a

-- | An extended parser type, with some support for printing parsers.
data ParserWithGrammar k r tok a
instance GHC.Base.Monad (Agda.Utils.Parser.MemoisedCPS.ParserWithGrammar k r tok)
instance GHC.Base.Functor (Agda.Utils.Parser.MemoisedCPS.ParserWithGrammar k r tok)
instance GHC.Base.Applicative (Agda.Utils.Parser.MemoisedCPS.ParserWithGrammar k r tok)
instance GHC.Base.Alternative (Agda.Utils.Parser.MemoisedCPS.ParserWithGrammar k r tok)
instance Agda.Utils.Parser.MemoisedCPS.ParserClass (Agda.Utils.Parser.MemoisedCPS.ParserWithGrammar k r tok) k r tok
instance Agda.Utils.Parser.MemoisedCPS.ParserClass (Agda.Utils.Parser.MemoisedCPS.Parser k r tok) k r tok
instance GHC.Base.Monad (Agda.Utils.Parser.MemoisedCPS.Parser k r tok)
instance GHC.Base.Functor (Agda.Utils.Parser.MemoisedCPS.Parser k r tok)
instance GHC.Base.Applicative (Agda.Utils.Parser.MemoisedCPS.Parser k r tok)
instance GHC.Base.Alternative (Agda.Utils.Parser.MemoisedCPS.Parser k r tok)


-- | Directed graphs (can of course simulate undirected graphs).
--   
--   Represented as adjacency maps in direction from source to target.
--   
--   Each source node maps to an adjacency map of outgoing edges, which is
--   a map from target nodes to edges.
--   
--   Listed time complexities are for the worst case (and possibly
--   amortised), with <i>n</i> standing for the number of nodes in the
--   graph and <i>e</i> standing for the number of edges. Comparisons,
--   predicates etc. are assumed to take constant time (unless otherwise
--   stated).
module Agda.Utils.Graph.AdjacencyMap.Unidirectional

-- | <tt>Graph n e</tt> is a type of directed graphs with nodes in
--   <tt>n</tt> and edges in <tt>e</tt>.
--   
--   At most one edge is allowed between any two nodes. Multigraphs can be
--   simulated by letting the edge type <tt>e</tt> be a collection type.
--   
--   The graphs are represented as adjacency maps (adjacency lists, but
--   using finite maps instead of arrays and lists). This makes it possible
--   to compute a node's outgoing edges in logarithmic time (<i>O(log
--   n)</i>). However, computing the incoming edges may be more expensive.
--   
--   Note that neither the number of nodes nor the number of edges may
--   exceed <tt><a>maxBound</a> :: <a>Int</a></tt>.
newtype Graph n e
Graph :: Map n (Map n e) -> Graph n e

-- | Forward edges.
[graph] :: Graph n e -> Map n (Map n e)

-- | Internal invariant.
invariant :: Ord n => Graph n e -> Bool

-- | Edges.
data Edge n e
Edge :: n -> n -> e -> Edge n e

-- | Outgoing node.
[source] :: Edge n e -> n

-- | Incoming node.
[target] :: Edge n e -> n

-- | Edge label (weight).
[label] :: Edge n e -> e

-- | If there is an edge from <tt>s</tt> to <tt>t</tt>, then <tt>lookup s t
--   g</tt> is <tt><a>Just</a> e</tt>, where <tt>e</tt> is the edge's
--   label. <i>O(log n)</i>.
lookup :: Ord n => n -> n -> Graph n e -> Maybe e

-- | The graph's edges. <i>O(n + e)</i>.
edges :: Graph n e -> [Edge n e]

-- | <tt>neighbours u g</tt> consists of all nodes <tt>v</tt> for which
--   there is an edge from <tt>u</tt> to <tt>v</tt> in <tt>g</tt>, along
--   with the corresponding edge labels. <i>O(log n + |<tt>neighbours u
--   g</tt>|)</i>.
neighbours :: Ord n => n -> Graph n e -> [(n, e)]

-- | <tt>neighboursMap u g</tt> consists of all nodes <tt>v</tt> for which
--   there is an edge from <tt>u</tt> to <tt>v</tt> in <tt>g</tt>, along
--   with the corresponding edge labels. <i>O(log n)</i>.
neighboursMap :: Ord n => n -> Graph n e -> Map n e

-- | <tt>edgesFrom g ns</tt> is a list containing all edges originating in
--   the given nodes (i.e., all outgoing edges for the given nodes). If
--   <tt>ns</tt> does not contain duplicates, then the resulting list does
--   not contain duplicates. <i>O(|<tt>ns</tt>| log |<tt>n</tt>| +
--   |<tt>edgesFrom g ns</tt>|)</i>.
edgesFrom :: Ord n => Graph n e -> [n] -> [Edge n e]

-- | <tt>edgesTo g ns</tt> is a list containing all edges ending in the
--   given nodes (i.e., all incoming edges for the given nodes). If
--   <tt>ns</tt> does not contain duplicates, then the resulting list does
--   not contain duplicates. <i>O(|<tt>ns</tt>| n log n)</i>.
edgesTo :: Ord n => Graph n e -> [n] -> [Edge n e]

-- | All self-loops. <i>O(n log n)</i>.
diagonal :: Ord n => Graph n e -> [Edge n e]

-- | All nodes. <i>O(n)</i>.
nodes :: Graph n e -> Set n

-- | Nodes with outgoing edges. <i>O(n)</i>.
sourceNodes :: Graph n e -> Set n

-- | Nodes with incoming edges. <i>O(n + e log n)</i>.
targetNodes :: Ord n => Graph n e -> Set n

-- | Nodes without incoming or outgoing edges. <i>O(n + e log n)</i>.
isolatedNodes :: Ord n => Graph n e -> Set n

-- | Various kinds of nodes.
data Nodes n
Nodes :: Set n -> Set n -> Set n -> Nodes n

-- | Nodes with outgoing edges.
[srcNodes] :: Nodes n -> Set n

-- | Nodes with incoming edges.
[tgtNodes] :: Nodes n -> Set n

-- | All nodes, with or without edges.
[allNodes] :: Nodes n -> Set n

-- | Constructs a <a>Nodes</a> structure. <i>O(n + e log n)</i>.
computeNodes :: Ord n => Graph n e -> Nodes n

-- | Checks whether the graph is discrete (containing no edges other than
--   <a>null</a> edges). <i>O(n + e)</i>.
discrete :: Null e => Graph n e -> Bool

-- | Returns <tt>True</tt> iff the graph is acyclic.
acyclic :: Ord n => Graph n e -> Bool

-- | Constructs a completely disconnected graph containing the given nodes.
--   <i>O(n log n)</i>.
fromNodes :: Ord n => [n] -> Graph n e

-- | Constructs a completely disconnected graph containing the given nodes.
--   <i>O(n)</i>.
fromNodeSet :: Ord n => Set n -> Graph n e

-- | <tt>fromEdges es</tt> is a graph containing the edges in <tt>es</tt>,
--   with the caveat that later edges overwrite earlier edges.
--   <i>O(|<tt>es</tt>| log n)</i>.
fromEdges :: Ord n => [Edge n e] -> Graph n e

-- | <tt>fromEdgesWith f es</tt> is a graph containing the edges in
--   <tt>es</tt>. Later edges are combined with earlier edges using the
--   supplied function. <i>O(|<tt>es</tt>| log n)</i>.
fromEdgesWith :: Ord n => (e -> e -> e) -> [Edge n e] -> Graph n e

-- | Empty graph (no nodes, no edges). <i>O(1)</i>.
empty :: Graph n e

-- | A graph with two nodes and a single connecting edge. <i>O(1)</i>.
singleton :: Ord n => n -> n -> e -> Graph n e

-- | Inserts an edge into the graph. <i>O(log n)</i>.
insert :: Ord n => n -> n -> e -> Graph n e -> Graph n e

-- | <tt>insertWith f s t new</tt> inserts an edge from <tt>s</tt> to
--   <tt>t</tt> into the graph. If there is already an edge from <tt>s</tt>
--   to <tt>t</tt> with label <tt>old</tt>, then this edge gets replaced by
--   an edge with label <tt>f new old</tt>, and otherwise the edge's label
--   is <tt>new</tt>. <i>O(log n)</i>.
insertWith :: Ord n => (e -> e -> e) -> n -> n -> e -> Graph n e -> Graph n e

-- | Inserts an edge into the graph. <i>O(log n)</i>.
insertEdge :: Ord n => Edge n e -> Graph n e -> Graph n e

-- | A variant of <a>insertWith</a>. <i>O(log n)</i>.
insertEdgeWith :: Ord n => (e -> e -> e) -> Edge n e -> Graph n e -> Graph n e

-- | Left-biased union.
--   
--   Time complexity: See <a>unionWith</a>.
union :: Ord n => Graph n e -> Graph n e -> Graph n e

-- | Union. The function is used to combine edge labels for edges that
--   occur in both graphs (labels from the first graph are given as the
--   first argument to the function).
--   
--   Time complexity: <i>O(n₁ log (n₂</i>n₁ + 1) + e₁ log e₂)<i>, where
--   </i>n₁/ is the number of nodes in the graph with the smallest number
--   of nodes and <i>n₂</i> is the number of nodes in the other graph, and
--   <i>e₁</i> is the number of edges in the graph with the smallest number
--   of edges and <i>e₂</i> is the number of edges in the other graph.
--   
--   Less complicated time complexity: <i>O((n + e) log n</i> (where
--   <i>n</i> and <i>e</i> refer to the resulting graph).
unionWith :: Ord n => (e -> e -> e) -> Graph n e -> Graph n e -> Graph n e

-- | Union. <i>O((n + e) log n</i> (where <i>n</i> and <i>e</i> refer to
--   the resulting graph).
unions :: Ord n => [Graph n e] -> Graph n e

-- | Union. The function is used to combine edge labels for edges that
--   occur in several graphs. <i>O((n + e) log n</i> (where <i>n</i> and
--   <i>e</i> refer to the resulting graph).
unionsWith :: Ord n => (e -> e -> e) -> [Graph n e] -> Graph n e

-- | A variant of <a>fmap</a> that provides extra information to the
--   function argument. <i>O(n + e)</i>.
mapWithEdge :: (Edge n e -> e') -> Graph n e -> Graph n e'

-- | Reverses an edge. <i>O(1)</i>.
transposeEdge :: Edge n e -> Edge n e

-- | The opposite graph (with all edges reversed). <i>O((n + e) log n)</i>.
transpose :: Ord n => Graph n e -> Graph n e

-- | Removes <a>null</a> edges. <i>O(n + e)</i>.
clean :: Null e => Graph n e -> Graph n e

-- | <tt>removeNode n g</tt> removes the node <tt>n</tt> (and all
--   corresponding edges) from <tt>g</tt>. <i>O(n + e)</i>.
removeNode :: Ord n => n -> Graph n e -> Graph n e

-- | <tt>removeNodes ns g</tt> removes the nodes in <tt>ns</tt> (and all
--   corresponding edges) from <tt>g</tt>. <i>O((n + e) log
--   |<tt>ns</tt>|)</i>.
removeNodes :: Ord n => Set n -> Graph n e -> Graph n e

-- | <tt>removeEdge s t g</tt> removes the edge going from <tt>s</tt> to
--   <tt>t</tt>, if any. <i>O(log n)</i>.
removeEdge :: Ord n => n -> n -> Graph n e -> Graph n e

-- | The graph <tt>filterNodes p g</tt> contains exactly those nodes from
--   <tt>g</tt> that satisfy the predicate <tt>p</tt>. Edges to or from
--   nodes that are removed are also removed. <i>O(n + e)</i>.
filterNodes :: Ord n => (n -> Bool) -> Graph n e -> Graph n e

-- | Keep only the edges that satisfy the predicate. <i>O(n + e)</i>.
filterEdges :: (Edge n e -> Bool) -> Graph n e -> Graph n e

-- | Removes the nodes that do not satisfy the predicate from the graph,
--   but keeps the edges: if there is a path in the original graph between
--   two nodes that are retained, then there is a path between these two
--   nodes also in the resulting graph.
--   
--   Precondition: The graph must be acyclic.
--   
--   Worst-case time complexity: <i>O(e n log n)</i> (this has not been
--   verified carefully).
filterNodesKeepingEdges :: forall n e. (Ord n, SemiRing e) => (n -> Bool) -> Graph n e -> Graph n e

-- | Renames the nodes.
--   
--   Precondition: The renaming function must be injective.
--   
--   Time complexity: <i>O((n + e) log n)</i>.
renameNodes :: Ord n2 => (n1 -> n2) -> Graph n1 e -> Graph n2 e

-- | Renames the nodes.
--   
--   Precondition: The renaming function <tt>ren</tt> must be strictly
--   increasing (if <tt>x <a>&lt;</a> y</tt> then <tt>ren x <a>&lt;</a> ren
--   y</tt>).
--   
--   Time complexity: <i>O(n + e)</i>.
renameNodesMonotonic :: (Ord n1, Ord n2) => (n1 -> n2) -> Graph n1 e -> Graph n2 e

-- | <tt>WithUniqueInt n</tt> consists of pairs of (unique) <a>Int</a>s and
--   values of type <tt>n</tt>.
--   
--   Values of this type are compared by comparing the <a>Int</a>s.
data WithUniqueInt n
WithUniqueInt :: !Int -> !n -> WithUniqueInt n
[uniqueInt] :: WithUniqueInt n -> !Int
[otherValue] :: WithUniqueInt n -> !n

-- | Combines each node label with a unique <a>Int</a>.
--   
--   Precondition: The number of nodes in the graph must not be larger than
--   <tt><a>maxBound</a> :: <a>Int</a></tt>.
--   
--   Time complexity: <i>O(n + e log n)</i>.
addUniqueInts :: forall n e. Ord n => Graph n e -> Graph (WithUniqueInt n) e

-- | Unzips the graph. <i>O(n + e)</i>.
unzip :: Graph n (e, e') -> (Graph n e, Graph n e')

-- | <tt>composeWith times plus g g'</tt> finds all edges <tt>s --c_i--&gt;
--   t_i --d_i--&gt; u</tt> and constructs the result graph from
--   <tt>edge(s,u) = sum_i (c_i times d_i)</tt>.
--   
--   Complexity: For each edge <tt>s --&gt; t</tt> in <tt>g</tt> we look up
--   all edges starting with <tt>t</tt> in <tt>g'</tt>.
--   
--   Precondition: The two graphs must have exactly the same nodes.
composeWith :: Ord n => (c -> d -> e) -> (e -> e -> e) -> Graph n c -> Graph n d -> Graph n e

-- | The graph's strongly connected components, in reverse topological
--   order.
--   
--   The time complexity is likely <i>O(n + e log n)</i> (but this depends
--   on the, at the time of writing undocumented, time complexity of
--   <a>stronglyConnComp</a>).
sccs' :: Ord n => Graph n e -> [SCC n]

-- | The graph's strongly connected components, in reverse topological
--   order.
--   
--   The time complexity is likely <i>O(n + e log n)</i> (but this depends
--   on the, at the time of writing undocumented, time complexity of
--   <a>stronglyConnComp</a>).
sccs :: Ord n => Graph n e -> [List1 n]

-- | SCC DAGs.
--   
--   The maps map SCC indices to and from SCCs/nodes.
data DAG n
DAG :: Graph -> IntMap (SCC n) -> Map n Int -> DAG n
[dagGraph] :: DAG n -> Graph
[dagComponentMap] :: DAG n -> IntMap (SCC n)
[dagNodeMap] :: DAG n -> Map n Int

-- | <a>DAG</a> invariant.
dagInvariant :: Ord n => DAG n -> Bool

-- | The opposite DAG.
oppositeDAG :: DAG n -> DAG n

-- | The nodes reachable from the given SCC.
reachable :: Ord n => DAG n -> SCC n -> [n]

-- | Constructs a DAG containing the graph's strongly connected components.
sccDAG' :: forall n e. Ord n => Graph n e -> [SCC n] -> DAG n

-- | Constructs a DAG containing the graph's strongly connected components.
sccDAG :: Ord n => Graph n e -> DAG n

-- | <tt>reachableFrom g n</tt> is a map containing all nodes reachable
--   from <tt>n</tt> in <tt>g</tt>. For each node a simple path to the node
--   is given, along with its length (the number of edges). The paths are
--   as short as possible (in terms of the number of edges).
--   
--   Precondition: <tt>n</tt> must be a node in <tt>g</tt>. The number of
--   nodes in the graph must not be larger than <tt><a>maxBound</a> ::
--   <a>Int</a></tt>.
--   
--   Amortised time complexity (assuming that comparisons take constant
--   time): <i>O(e log n)</i>, if the lists are not inspected. Inspection
--   of a prefix of a list is linear in the length of the prefix.
reachableFrom :: Ord n => Graph n e -> n -> Map n (Int, [Edge n e])

-- | <tt>reachableFromSet g ns</tt> is a set containing all nodes reachable
--   from <tt>ns</tt> in <tt>g</tt>.
--   
--   Precondition: Every node in <tt>ns</tt> must be a node in <tt>g</tt>.
--   The number of nodes in the graph must not be larger than
--   <tt><a>maxBound</a> :: <a>Int</a></tt>.
--   
--   Amortised time complexity (assuming that comparisons take constant
--   time): <i>O((|<tt>ns</tt>| + e) log n)</i>.
reachableFromSet :: Ord n => Graph n e -> Set n -> Set n

-- | <tt>walkSatisfying every some g from to</tt> determines if there is a
--   walk from <tt>from</tt> to <tt>to</tt> in <tt>g</tt>, in which every
--   edge satisfies the predicate <tt>every</tt>, and some edge satisfies
--   the predicate <tt>some</tt>. If there are several such walks, then a
--   shortest one (in terms of the number of edges) is returned.
--   
--   Precondition: <tt>from</tt> and <tt>to</tt> must be nodes in
--   <tt>g</tt>. The number of nodes in the graph must not be larger than
--   <tt><a>maxBound</a> :: <a>Int</a></tt>.
--   
--   Amortised time complexity (assuming that comparisons and the
--   predicates take constant time to compute): <i>O(n + e log n)</i>.
walkSatisfying :: Ord n => (Edge n e -> Bool) -> (Edge n e -> Bool) -> Graph n e -> n -> n -> Maybe [Edge n e]

-- | Constructs a graph <tt>g'</tt> with the same nodes as the original
--   graph <tt>g</tt>. In <tt>g'</tt> there is an edge from <tt>n1</tt> to
--   <tt>n2</tt> if and only if there is a (possibly empty) simple path
--   from <tt>n1</tt> to <tt>n2</tt> in <tt>g</tt>. In that case the edge
--   is labelled with all of the longest (in terms of numbers of edges)
--   simple paths from <tt>n1</tt> to <tt>n2</tt> in <tt>g</tt>, as well as
--   the lengths of these paths.
--   
--   Precondition: The graph must be acyclic. The number of nodes in the
--   graph must not be larger than <tt><a>maxBound</a> :: <a>Int</a></tt>.
--   
--   Worst-case time complexity (if the paths are not inspected): <i>O(e n
--   log n)</i> (this has not been verified carefully).
--   
--   The algorithm is based on one found on Wikipedia.
longestPaths :: forall n e. Ord n => Graph n e -> Graph n (Int, [[Edge n e]])

-- | Computes the transitive closure of the graph.
--   
--   Uses the Gauss-Jordan-Floyd-Warshall-McNaughton-Yamada algorithm (as
--   described by Russell O'Connor in "A Very General Method of Computing
--   Shortest Paths" <a>http://r6.ca/blog/20110808T035622Z.html</a>),
--   implemented using <a>Graph</a>, and with some shortcuts:
--   
--   <ul>
--   <li>Zero edge differences are not added to the graph, thus avoiding
--   some zero edges.</li>
--   <li>Strongly connected components are used to avoid computing some
--   zero edges.</li>
--   </ul>
--   
--   The graph's strongly connected components (in reverse topological
--   order) are returned along with the transitive closure.
gaussJordanFloydWarshallMcNaughtonYamada :: forall n e. (Ord n, Eq e, StarSemiRing e) => Graph n e -> (Graph n e, [SCC n])

-- | Computes the transitive closure of the graph.
--   
--   Uses the Gauss-Jordan-Floyd-Warshall-McNaughton-Yamada algorithm (as
--   described by Russell O'Connor in "A Very General Method of Computing
--   Shortest Paths" <a>http://r6.ca/blog/20110808T035622Z.html</a>),
--   implemented using matrices.
--   
--   The resulting graph does not contain any zero edges.
--   
--   This algorithm should be seen as a reference implementation. In
--   practice <a>gaussJordanFloydWarshallMcNaughtonYamada</a> is likely to
--   be more efficient.
gaussJordanFloydWarshallMcNaughtonYamadaReference :: forall n e. (Ord n, Eq e, StarSemiRing e) => Graph n e -> Graph n e

-- | The transitive closure. Using
--   <a>gaussJordanFloydWarshallMcNaughtonYamada</a>. NOTE: DO NOT USE ()
--   AS EDGE LABEL SINCE THIS MEANS EVERY EDGE IS CONSIDERED A ZERO EDGE
--   AND NO NEW EDGES WILL BE ADDED! Use 'Maybe ()' instead.
transitiveClosure :: (Ord n, Eq e, StarSemiRing e) => Graph n e -> Graph n e

-- | The transitive reduction of the graph: a graph with the same
--   reachability relation as the graph, but with as few edges as possible.
--   
--   Precondition: The graph must be acyclic. The number of nodes in the
--   graph must not be larger than <tt><a>maxBound</a> :: <a>Int</a></tt>.
--   
--   Worst-case time complexity: <i>O(e n log n)</i> (this has not been
--   verified carefully).
--   
--   The algorithm is based on one found on Wikipedia.
transitiveReduction :: Ord n => Graph n e -> Graph n ()

-- | Transitive closure ported from <a>Agda.Termination.CallGraph</a>.
--   
--   Relatively efficient, see Issue 1560.
complete :: (Eq e, Null e, SemiRing e, Ord n) => Graph n e -> Graph n e

-- | Version of <a>complete</a> that produces a list of intermediate
--   results paired to the left with a difference that lead to the new
--   intermediat result.
--   
--   The last element in the list is the transitive closure, paired with
--   the empty graph.
--   
--   <pre>
--   complete g = snd $ last $ completeIter g
--   </pre>
completeIter :: (Eq e, Null e, SemiRing e, Ord n) => Graph n e -> [(Graph n e, Graph n e)]
instance (GHC.Classes.Eq n, GHC.Classes.Eq e) => GHC.Classes.Eq (Agda.Utils.Graph.AdjacencyMap.Unidirectional.Graph n e)
instance (GHC.Show.Show n, GHC.Show.Show e) => GHC.Show.Show (Agda.Utils.Graph.AdjacencyMap.Unidirectional.Edge n e)
instance GHC.Base.Functor (Agda.Utils.Graph.AdjacencyMap.Unidirectional.Edge n)
instance (GHC.Classes.Ord n, GHC.Classes.Ord e) => GHC.Classes.Ord (Agda.Utils.Graph.AdjacencyMap.Unidirectional.Edge n e)
instance (GHC.Classes.Eq n, GHC.Classes.Eq e) => GHC.Classes.Eq (Agda.Utils.Graph.AdjacencyMap.Unidirectional.Edge n e)
instance GHC.Base.Functor Agda.Utils.Graph.AdjacencyMap.Unidirectional.WithUniqueInt
instance GHC.Show.Show n => GHC.Show.Show (Agda.Utils.Graph.AdjacencyMap.Unidirectional.WithUniqueInt n)
instance GHC.Classes.Eq (Agda.Utils.Graph.AdjacencyMap.Unidirectional.WithUniqueInt n)
instance GHC.Classes.Ord (Agda.Utils.Graph.AdjacencyMap.Unidirectional.WithUniqueInt n)
instance Agda.Syntax.Common.Pretty.Pretty n => Agda.Syntax.Common.Pretty.Pretty (Agda.Utils.Graph.AdjacencyMap.Unidirectional.WithUniqueInt n)
instance (Agda.Syntax.Common.Pretty.Pretty n, Agda.Syntax.Common.Pretty.Pretty e) => Agda.Syntax.Common.Pretty.Pretty (Agda.Utils.Graph.AdjacencyMap.Unidirectional.Edge n e)
instance GHC.Base.Functor (Agda.Utils.Graph.AdjacencyMap.Unidirectional.Graph n)
instance (GHC.Classes.Ord n, Agda.Syntax.Common.Pretty.Pretty n, Agda.Syntax.Common.Pretty.Pretty e) => Agda.Syntax.Common.Pretty.Pretty (Agda.Utils.Graph.AdjacencyMap.Unidirectional.Graph n e)
instance (GHC.Classes.Ord n, GHC.Show.Show n, GHC.Show.Show e) => GHC.Show.Show (Agda.Utils.Graph.AdjacencyMap.Unidirectional.Graph n e)

module Agda.Utils.Graph.TopSort

-- | topoligical sort with smallest-numbered available vertex first |
--   input: nodes, edges | output is Nothing if the graph is not a DAG
--   Note: should be stable to preserve order of generalizable variables.
--   Algorithm due to Richard Eisenberg, and works by walking over the list
--   left-to-right and moving each node the minimum distance left to
--   guarantee topological ordering.
topSort :: Ord n => Set n -> [(n, n)] -> Maybe [n]

module Agda.Utils.CallStack

-- | <a>CallStack</a>s are a lightweight method of obtaining a partial
--   call-stack at any point in the program.
--   
--   A function can request its call-site with the <a>HasCallStack</a>
--   constraint. For example, we can define
--   
--   <pre>
--   putStrLnWithCallStack :: HasCallStack =&gt; String -&gt; IO ()
--   </pre>
--   
--   as a variant of <tt>putStrLn</tt> that will get its call-site and
--   print it, along with the string given as argument. We can access the
--   call-stack inside <tt>putStrLnWithCallStack</tt> with
--   <a>callStack</a>.
--   
--   <pre>
--   &gt;&gt;&gt; :{
--   putStrLnWithCallStack :: HasCallStack =&gt; String -&gt; IO ()
--   putStrLnWithCallStack msg = do
--     putStrLn msg
--     putStrLn (prettyCallStack callStack)
--   :}
--   </pre>
--   
--   Thus, if we call <tt>putStrLnWithCallStack</tt> we will get a
--   formatted call-stack alongside our string.
--   
--   <pre>
--   &gt;&gt;&gt; putStrLnWithCallStack "hello"
--   hello
--   CallStack (from HasCallStack):
--     putStrLnWithCallStack, called at &lt;interactive&gt;:... in interactive:Ghci...
--   </pre>
--   
--   GHC solves <a>HasCallStack</a> constraints in three steps:
--   
--   <ol>
--   <li>If there is a <a>CallStack</a> in scope -- i.e. the enclosing
--   function has a <a>HasCallStack</a> constraint -- GHC will append the
--   new call-site to the existing <a>CallStack</a>.</li>
--   <li>If there is no <a>CallStack</a> in scope -- e.g. in the GHCi
--   session above -- and the enclosing definition does not have an
--   explicit type signature, GHC will infer a <a>HasCallStack</a>
--   constraint for the enclosing definition (subject to the monomorphism
--   restriction).</li>
--   <li>If there is no <a>CallStack</a> in scope and the enclosing
--   definition has an explicit type signature, GHC will solve the
--   <a>HasCallStack</a> constraint for the singleton <a>CallStack</a>
--   containing just the current call-site.</li>
--   </ol>
--   
--   <a>CallStack</a>s do not interact with the RTS and do not require
--   compilation with <tt>-prof</tt>. On the other hand, as they are built
--   up explicitly via the <a>HasCallStack</a> constraints, they will
--   generally not contain as much information as the simulated call-stacks
--   maintained by the RTS.
--   
--   A <a>CallStack</a> is a <tt>[(String, SrcLoc)]</tt>. The
--   <tt>String</tt> is the name of function that was called, the
--   <a>SrcLoc</a> is the call-site. The list is ordered with the most
--   recently called function at the head.
--   
--   NOTE: The intrepid user may notice that <a>HasCallStack</a> is just an
--   alias for an implicit parameter <tt>?callStack :: CallStack</tt>. This
--   is an implementation detail and <b>should not</b> be considered part
--   of the <a>CallStack</a> API, we may decide to change the
--   implementation in the future.
data () => CallStack

-- | A single location in the source code.
data () => SrcLoc
SrcLoc :: [Char] -> [Char] -> [Char] -> Int -> Int -> Int -> Int -> SrcLoc
[srcLocPackage] :: SrcLoc -> [Char]
[srcLocModule] :: SrcLoc -> [Char]
[srcLocFile] :: SrcLoc -> [Char]
[srcLocStartLine] :: SrcLoc -> Int
[srcLocStartCol] :: SrcLoc -> Int
[srcLocEndLine] :: SrcLoc -> Int
[srcLocEndCol] :: SrcLoc -> Int

-- | Request a CallStack.
--   
--   NOTE: The implicit parameter <tt>?callStack :: CallStack</tt> is an
--   implementation detail and <b>should not</b> be considered part of the
--   <a>CallStack</a> API, we may decide to change the implementation in
--   the future.
type HasCallStack = ?callStack :: CallStack

-- | Type of the package name of a <tt>SrcLoc</tt> | e.g. `Agda-2.…`
type SrcLocPackage = String

-- | Type of the module name of a <tt>SrcLoc</tt> | e.g. <a>Foo</a>
type SrcLocModule = String

-- | Type of the name of a function in a <tt>CallSite</tt> | e.g.
--   <tt>proveEverything</tt>
type SrcFun = String

-- | Type of a filename of a <tt>SrcLoc</tt> | e.g.
--   `src<i>full</i>Agda<i>Utils</i>Foo.hs`
type SrcLocFile = String

-- | Type of a line number of a <tt>SrcLoc</tt>
type SrcLocLine = Int

-- | Type of a column of a <tt>SrcLoc</tt>
type SrcLocCol = Int

-- | Type of an entry in a <tt>CallStack</tt>
type CallSite = (SrcFun, SrcLoc)

-- | Type of a filter for <tt>CallSite</tt>
type CallSiteFilter = CallSite -> Bool

-- | Return the current <a>CallStack</a>.
--   
--   Does *not* include the call-site of <a>callStack</a>.
callStack :: HasCallStack => CallStack

-- | Extract a list of call-sites from the <a>CallStack</a>.
--   
--   The list is ordered by most recent call.
getCallStack :: CallStack -> [([Char], SrcLoc)]

-- | Convert a list of call-sites to a <a>CallStack</a>.
fromCallSiteList :: [([Char], SrcLoc)] -> CallStack

-- | Pretty print a <a>SrcLoc</a>.
prettySrcLoc :: SrcLoc -> String

-- | Pretty-print a <tt>CallStack</tt>. This has a few differences from
--   <tt>GHC.Stack.prettyCallStackLines</tt>. We omit the "CallStack (from
--   GetCallStack)" header line for brevity. If there is only one entry
--   (which is common, due to the manual nature of the
--   <tt>HasCallStack</tt> constraint), shows the entry on one line. If
--   there are multiple, then the following lines are indented.
prettyCallStack :: CallStack -> String
withCallerCallStack :: HasCallStack => (CallStack -> b) -> b

-- | The same as the un-exported internal function in <tt>GHC.Exceptions
--   (prettyCallStackLines)</tt> Prints like: <tt>doFoo, called at
--   foo.hs:190:24 in main:Main</tt>
prettyCallSite :: CallSite -> String

-- | Get the most recent <tt>CallSite</tt> in a <tt>CallStack</tt>, if
--   there is one.
headCallSite :: CallStack -> Maybe CallSite
withCurrentCallStack :: HasCallStack => (CallStack -> b) -> b

-- | Transform a <tt>CallStack</tt> by filtering each <tt>CallSite</tt>
filterCallStack :: CallSiteFilter -> CallStack -> CallStack

-- | Transform a <tt>CallStack</tt> by transforming its list of
--   <tt>CallSite</tt>
overCallSites :: ([CallSite] -> [CallSite]) -> CallStack -> CallStack

-- | Pops n entries off a <tt>CallStack</tt> using <tt>popCallStack</tt>.
--   Note that frozen callstacks are unaffected.
popnCallStack :: Word -> CallStack -> CallStack

-- | <tt>CallStack</tt> comprising only the most recent <tt>CallSite</tt>
truncatedCallStack :: CallStack -> CallStack
withNBackCallStack :: HasCallStack => Word -> (CallStack -> b) -> b


-- | Tools for benchmarking and accumulating results. Nothing Agda-specific
--   in here.
module Agda.Utils.Benchmark

-- | Account we can bill computation time to.
type Account a = [a]

-- | Record when we started billing the current account.
type CurrentAccount a = Maybe (Account a, CPUTime)
type Timings a = Trie a CPUTime
data BenchmarkOn a
BenchmarkOff :: BenchmarkOn a
BenchmarkOn :: BenchmarkOn a
BenchmarkSome :: (Account a -> Bool) -> BenchmarkOn a
isBenchmarkOn :: Account a -> BenchmarkOn a -> Bool

-- | Benchmark structure is a trie, mapping accounts (phases and subphases)
--   to CPU time spent on their performance.
data Benchmark a
Benchmark :: !BenchmarkOn a -> !CurrentAccount a -> !Timings a -> Benchmark a

-- | Are we benchmarking at all?
[benchmarkOn] :: Benchmark a -> !BenchmarkOn a

-- | What are we billing to currently?
[currentAccount] :: Benchmark a -> !CurrentAccount a

-- | The accounts and their accumulated timing bill.
[timings] :: Benchmark a -> !Timings a

-- | Semantic editor combinator.
mapBenchmarkOn :: (BenchmarkOn a -> BenchmarkOn a) -> Benchmark a -> Benchmark a

-- | Semantic editor combinator.
mapCurrentAccount :: (CurrentAccount a -> CurrentAccount a) -> Benchmark a -> Benchmark a

-- | Semantic editor combinator.
mapTimings :: (Timings a -> Timings a) -> Benchmark a -> Benchmark a

-- | Add to specified CPU time account.
addCPUTime :: Ord a => Account a -> CPUTime -> Benchmark a -> Benchmark a

-- | Monad with access to benchmarking data.
class (Ord (BenchPhase m), Functor m, MonadIO m) => MonadBench m where {
    type BenchPhase m;
}
getBenchmark :: MonadBench m => m (Benchmark (BenchPhase m))
putBenchmark :: MonadBench m => Benchmark (BenchPhase m) -> m ()
modifyBenchmark :: MonadBench m => (Benchmark (BenchPhase m) -> Benchmark (BenchPhase m)) -> m ()

-- | We need to be able to terminate benchmarking in case of an exception.
finally :: MonadBench m => m b -> m c -> m b
getsBenchmark :: MonadBench m => (Benchmark (BenchPhase m) -> c) -> m c

-- | Turn benchmarking on/off.
setBenchmarking :: MonadBench m => BenchmarkOn (BenchPhase m) -> m ()

-- | Bill current account with time up to now. Switch to new account.
--   Return old account (if any).
switchBenchmarking :: MonadBench m => Maybe (Account (BenchPhase m)) -> m (Maybe (Account (BenchPhase m)))

-- | Resets the account and the timing information.
reset :: MonadBench m => m ()

-- | Bill a computation to a specific account. Works even if the
--   computation is aborted by an exception.
billTo :: MonadBench m => Account (BenchPhase m) -> m c -> m c

-- | Bill a CPS function to an account. Can't handle exceptions.
billToCPS :: MonadBench m => Account (BenchPhase m) -> ((b -> m c) -> m c) -> (b -> m c) -> m c

-- | Bill a pure computation to a specific account.
billPureTo :: MonadBench m => Account (BenchPhase m) -> c -> m c
instance GHC.Generics.Generic (Agda.Utils.Benchmark.BenchmarkOn a)
instance GHC.Generics.Generic (Agda.Utils.Benchmark.Benchmark a)
instance Agda.Utils.Benchmark.MonadBench m => Agda.Utils.Benchmark.MonadBench (Control.Monad.Trans.Reader.ReaderT r m)
instance (Agda.Utils.Benchmark.MonadBench m, GHC.Base.Monoid w) => Agda.Utils.Benchmark.MonadBench (Control.Monad.Trans.Writer.Lazy.WriterT w m)
instance Agda.Utils.Benchmark.MonadBench m => Agda.Utils.Benchmark.MonadBench (Control.Monad.Trans.State.Lazy.StateT r m)
instance Agda.Utils.Benchmark.MonadBench m => Agda.Utils.Benchmark.MonadBench (Control.Monad.Trans.Except.ExceptT e m)
instance Agda.Utils.Benchmark.MonadBench m => Agda.Utils.Benchmark.MonadBench (Agda.Utils.ListT.ListT m)
instance Agda.Utils.Null.Null (Agda.Utils.Benchmark.Benchmark a)
instance (GHC.Classes.Ord a, Agda.Syntax.Common.Pretty.Pretty a) => Agda.Syntax.Common.Pretty.Pretty (Agda.Utils.Benchmark.Benchmark a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Utils.Benchmark.Benchmark a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Utils.Benchmark.BenchmarkOn a)


-- | Sparse matrices.
--   
--   We assume the matrices to be very sparse, so we just implement them as
--   sorted association lists.
--   
--   Most operations are linear in the number of non-zero elements.
--   
--   An exception is transposition, which needs to sort the association
--   list again; it has the complexity of sorting: <tt>n log n</tt> where
--   <tt>n</tt> is the number of non-zero elements.
--   
--   Another exception is matrix multiplication, of course.
module Agda.Termination.SparseMatrix

-- | Type of matrices, parameterised on the type of values.
--   
--   Sparse matrices are implemented as an ordered association list,
--   mapping coordinates to values.
data Matrix i b
Matrix :: Size i -> [(MIx i, b)] -> Matrix i b

-- | Association of indices to values.
unM :: Matrix i b -> [(MIx i, b)]

-- | Size of a matrix.
data Size i
Size :: i -> i -> Size i

-- | Number of rows, <tt>&gt;= 0</tt>.
[rows] :: Size i -> i

-- | Number of columns, <tt>&gt;= 0</tt>.
[cols] :: Size i -> i

-- | Type of matrix indices (row, column).
data MIx i
MIx :: i -> i -> MIx i

-- | Row index, <tt>1 &lt;= row &lt;= rows</tt>.
[row] :: MIx i -> i

-- | Column index <tt>1 &lt;= col &lt;= cols</tt>.
[col] :: MIx i -> i

-- | <tt><a>fromLists</a> sz rs</tt> constructs a matrix from a list of
--   lists of values (a list of rows). <tt>O(size)</tt> where <tt>size =
--   rows × cols</tt>.
--   
--   Precondition: <tt><a>length</a> rs <a>==</a> <a>rows</a> sz</tt> and
--   <tt><a>all</a> ((<a>cols</a> sz <a>==</a>) . <a>length</a>) rs</tt>.
fromLists :: (Ord i, Num i, Enum i, HasZero b) => Size i -> [[b]] -> Matrix i b

-- | Constructs a matrix from a list of <tt>(index, value)</tt>-pairs.
--   <tt>O(n)</tt> where <tt>n</tt> is size of the list.
--   
--   Precondition: indices are unique.
fromIndexList :: (Ord i, HasZero b) => Size i -> [(MIx i, b)] -> Matrix i b

-- | Converts a matrix to a list of row lists. <tt>O(size)</tt> where
--   <tt>size = rows × cols</tt>.
toLists :: (Integral i, HasZero b) => Matrix i b -> [[b]]

-- | Dimensions of the matrix.
size :: Matrix i b -> Size i

-- | <a>True</a> iff the matrix is square.
square :: Ix i => Matrix i b -> Bool

-- | Returns <a>True</a> iff the matrix is empty.
isEmpty :: (Num i, Ix i) => Matrix i b -> Bool

-- | Returns 'Just b' iff it is a 1x1 matrix with just one entry
--   <tt>b</tt>. <tt>O(1)</tt>.
isSingleton :: (Eq i, Num i, HasZero b) => Matrix i b -> Maybe b

-- | General pointwise combination function for sparse matrices. <tt>O(n1 +
--   n2)</tt>.
zipMatrices :: forall a b c i. Ord i => (a -> c) -> (b -> c) -> (a -> b -> c) -> (c -> Bool) -> Matrix i a -> Matrix i b -> Matrix i c

-- | <tt><a>add</a> (+) m1 m2</tt> adds <tt>m1</tt> and <tt>m2</tt>, using
--   <tt>(+)</tt> to add values. <tt>O(n1 + n2)</tt>.
--   
--   Returns a matrix of size <tt><a>supSize</a> m1 m2</tt>.
add :: (Ord i, HasZero a) => (a -> a -> a) -> Matrix i a -> Matrix i a -> Matrix i a

-- | <tt><a>intersectWith</a> f m1 m2</tt> build the pointwise conjunction
--   <tt>m1</tt> and <tt>m2</tt>. Uses <tt>f</tt> to combine non-zero
--   values. <tt>O(n1 + n2)</tt>.
--   
--   Returns a matrix of size <tt>infSize m1 m2</tt>.
intersectWith :: Ord i => (a -> a -> a) -> Matrix i a -> Matrix i a -> Matrix i a

-- | Association list intersection. <tt>O(n1 + n2)</tt>.
--   
--   <pre>
--   interAssocWith f l l' = { (i, f a b) | (i,a) ∈ l and (i,b) ∈ l' }
--   </pre>
--   
--   Used to combine sparse matrices, it might introduce zero elements if
--   <tt>f</tt> can return zero for non-zero arguments.
interAssocWith :: Ord i => (a -> a -> a) -> [(i, a)] -> [(i, a)] -> [(i, a)]

-- | <tt><a>mul</a> semiring m1 m2</tt> multiplies matrices <tt>m1</tt> and
--   <tt>m2</tt>. Uses the operations of the semiring <tt>semiring</tt> to
--   perform the multiplication.
--   
--   <tt>O(n1 + n2 log n2 + Σ(i &lt;= r1) Σ(j &lt;= c2) d(i,j))</tt> where
--   <tt>r1</tt> is the number of non-empty rows in <tt>m1</tt> and
--   <tt>c2</tt> is the number of non-empty columns in <tt>m2</tt> and
--   <tt>d(i,j)</tt> is the bigger one of the following two quantifies: the
--   length of sparse row <tt>i</tt> in <tt>m1</tt> and the length of
--   sparse column <tt>j</tt> in <tt>m2</tt>.
--   
--   Given dimensions <tt>m1 : r1 × c1</tt> and <tt>m2 : r2 × c2</tt>, a
--   matrix of size <tt>r1 × c2</tt> is returned. It is not necessary that
--   <tt>c1 == r2</tt>, the matrices are implicitly patched with zeros to
--   match up for multiplication. For sparse matrices, this patching is a
--   no-op.
mul :: (Ix i, Eq a) => Semiring a -> Matrix i a -> Matrix i a -> Matrix i a
transpose :: Transpose a => a -> a

-- | <tt><a>diagonal</a> m</tt> extracts the diagonal of <tt>m</tt>.
--   
--   For non-square matrices, the length of the diagonal is the minimum of
--   the dimensions of the matrix.
class Diagonal m e | m -> e
diagonal :: Diagonal m e => m -> [e]

-- | Converts a sparse matrix to a sparse list of rows. <tt>O(n)</tt> where
--   <tt>n</tt> is the number of non-zero entries of the matrix.
--   
--   Only non-empty rows are generated.
toSparseRows :: Eq i => Matrix i b -> [(i, [(i, b)])]

-- | Compute the matrix size of the union of two matrices.
supSize :: Ord i => Matrix i a -> Matrix i b -> Size i

-- | General pointwise combination function for association lists. <tt>O(n1
--   + n2)</tt> where <tt>ni</tt> is the number of non-zero element in
--   matrix <tt>i</tt>.
--   
--   In <tt>zipAssocWith fs gs f g h l l'</tt>,
--   
--   <tt>fs</tt> is possibly more efficient version of <tt><a>mapMaybe</a>
--   ( (i, a) -&gt; (i,) <a>$</a> f a)</tt>, and same for <tt>gs</tt> and
--   <tt>g</tt>.
zipAssocWith :: Ord i => ([(i, a)] -> [(i, c)]) -> ([(i, b)] -> [(i, c)]) -> (a -> Maybe c) -> (b -> Maybe c) -> (a -> b -> Maybe c) -> [(i, a)] -> [(i, b)] -> [(i, c)]

-- | <tt><a>addRow</a> x m</tt> adds a new row to <tt>m</tt>, after the
--   rows already existing in the matrix. All elements in the new row get
--   set to <tt>x</tt>.
addRow :: (Num i, HasZero b) => b -> Matrix i b -> Matrix i b

-- | <tt><a>addColumn</a> x m</tt> adds a new column to <tt>m</tt>, after
--   the columns already existing in the matrix. All elements in the new
--   column get set to <tt>x</tt>.
addColumn :: (Num i, HasZero b) => b -> Matrix i b -> Matrix i b
instance GHC.Show.Show i => GHC.Show.Show (Agda.Termination.SparseMatrix.Size i)
instance GHC.Classes.Ord i => GHC.Classes.Ord (Agda.Termination.SparseMatrix.Size i)
instance GHC.Classes.Eq i => GHC.Classes.Eq (Agda.Termination.SparseMatrix.Size i)
instance GHC.Ix.Ix i => GHC.Ix.Ix (Agda.Termination.SparseMatrix.MIx i)
instance GHC.Show.Show i => GHC.Show.Show (Agda.Termination.SparseMatrix.MIx i)
instance GHC.Classes.Ord i => GHC.Classes.Ord (Agda.Termination.SparseMatrix.MIx i)
instance GHC.Classes.Eq i => GHC.Classes.Eq (Agda.Termination.SparseMatrix.MIx i)
instance Data.Traversable.Traversable (Agda.Termination.SparseMatrix.Matrix i)
instance Data.Foldable.Foldable (Agda.Termination.SparseMatrix.Matrix i)
instance GHC.Base.Functor (Agda.Termination.SparseMatrix.Matrix i)
instance (GHC.Classes.Ord i, GHC.Classes.Ord b) => GHC.Classes.Ord (Agda.Termination.SparseMatrix.Matrix i b)
instance (GHC.Classes.Eq i, GHC.Classes.Eq b) => GHC.Classes.Eq (Agda.Termination.SparseMatrix.Matrix i b)
instance Agda.Termination.SparseMatrix.Transpose (Agda.Termination.SparseMatrix.Size i)
instance Agda.Termination.SparseMatrix.Transpose (Agda.Termination.SparseMatrix.MIx i)
instance GHC.Classes.Ord i => Agda.Termination.SparseMatrix.Transpose (Agda.Termination.SparseMatrix.Matrix i b)
instance (GHC.Real.Integral i, Agda.Termination.Semiring.HasZero b, Agda.Syntax.Common.Pretty.Pretty b) => Agda.Syntax.Common.Pretty.Pretty (Agda.Termination.SparseMatrix.Matrix i b)
instance (GHC.Real.Integral i, Agda.Termination.Semiring.HasZero b) => Agda.Termination.SparseMatrix.Diagonal (Agda.Termination.SparseMatrix.Matrix i b) b
instance (GHC.Classes.Ord i, Agda.Utils.PartialOrd.PartialOrd a) => Agda.Utils.PartialOrd.PartialOrd (Agda.Termination.SparseMatrix.Matrix i a)
instance (GHC.Real.Integral i, Agda.Termination.Semiring.HasZero b, GHC.Show.Show i, GHC.Show.Show b) => GHC.Show.Show (Agda.Termination.SparseMatrix.Matrix i b)


-- | An Abstract domain of relative sizes, i.e., differences between size
--   of formal function parameter and function argument in recursive call;
--   used in the termination checker.
module Agda.Termination.Order

-- | In the paper referred to above, there is an order R with
--   <tt><a>Unknown</a> <a>&lt;=</a> <tt>Le</tt> <a>&lt;=</a>
--   <tt>Lt</tt></tt>.
--   
--   This is generalized to <tt><a>Unknown</a> <a>&lt;=</a> 'Decr k'</tt>
--   where <tt>Decr 1</tt> replaces <tt>Lt</tt> and <tt>Decr 0</tt>
--   replaces <tt>Le</tt>. A negative decrease means an increase. The
--   generalization allows the termination checker to record an increase by
--   1 which can be compensated by a following decrease by 2 which results
--   in an overall decrease.
--   
--   However, the termination checker of the paper itself terminates
--   because there are only finitely many different call-matrices. To
--   maintain termination of the terminator we set a <tt>cutoff</tt> point
--   which determines how high the termination checker can count. This
--   value should be set by a global or file-wise option.
--   
--   See <tt>Call</tt> for more information.
--   
--   TODO: document orders which are call-matrices themselves.
data Order

-- | Decrease of callee argument wrt. caller parameter.
--   
--   The <tt>Bool</tt> indicates whether the decrease (if any) is usable.
--   In any chain, there needs to be one usable decrease. Unusable
--   decreases come from SIZELT constraints which are not in inductive
--   pattern match or a coinductive copattern match. See issue #2331.
--   
--   UPDATE: Andreas, 2017-07-26: Feature #2331 is unsound due to size
--   quantification in terms. While the infrastructure for usable/unusable
--   decrease remains in place, no unusable decreases are generated by
--   TermCheck.
Decr :: !Bool -> {-# UNPACK #-} !Int -> Order

-- | No relation, infinite increase, or increase beyond termination depth.
Unknown :: Order

-- | Matrix-shaped order, currently UNUSED.
Mat :: {-# UNPACK #-} !Matrix Int Order -> Order

-- | Smart constructor for <tt>Decr k :: Order</tt> which cuts off too big
--   values.
--   
--   Possible values for <tt>k</tt>: <tt>- ?cutoff <a>&lt;=</a> k
--   <a>&lt;=</a> ?cutoff + 1</tt>.
decr :: (?cutoff :: CutOff) => Bool -> Int -> Order

-- | Raw increase which does not cut off.
increase :: Int -> Order -> Order

-- | Raw decrease which does not cut off.
decrease :: Int -> Order -> Order
setUsability :: Bool -> Order -> Order

-- | Multiplication of <a>Order</a>s. (Corresponds to sequential
--   composition.)
(.*.) :: (?cutoff :: CutOff) => Order -> Order -> Order

-- | The supremum of a (possibly empty) list of <a>Order</a>s. More
--   information (i.e., more decrease) is bigger. <a>Unknown</a> is no
--   information, thus, smallest.
supremum :: (?cutoff :: CutOff) => [Order] -> Order

-- | The infimum of a (non empty) list of <a>Order</a>s. Gets the worst
--   information. <a>Unknown</a> is the least element, thus, dominant.
infimum :: (?cutoff :: CutOff) => [Order] -> Order

-- | We use a record for semiring instead of a type class since implicit
--   arguments cannot occur in instance constraints, like <tt>instance
--   (?cutoff :: Int) =&gt; SemiRing Order</tt>.
orderSemiring :: (?cutoff :: CutOff) => Semiring Order

-- | <tt>le</tt>, <tt>lt</tt>, <tt>decreasing</tt>, <tt>unknown</tt>: for
--   backwards compatibility, and for external use.
le :: Order

-- | Usable decrease.
lt :: Order
unknown :: Order

-- | Smart constructor for matrix shaped orders, avoiding empty and
--   singleton matrices.
orderMat :: Matrix Int Order -> Order
collapseO :: (?cutoff :: CutOff) => Order -> Order
nonIncreasing :: Order -> Bool

-- | Decreasing and usable?
decreasing :: Order -> Bool

-- | Matrix-shaped order is decreasing if any diagonal element is
--   decreasing.
isDecr :: Order -> Bool

-- | A partial order, aimed at deciding whether a call graph gets worse
--   during the completion.
class NotWorse a
notWorse :: NotWorse a => a -> a -> Bool
isOrder :: (?cutoff :: CutOff) => Order -> Bool
instance GHC.Show.Show Agda.Termination.Order.Order
instance GHC.Classes.Ord Agda.Termination.Order.Order
instance GHC.Classes.Eq Agda.Termination.Order.Order
instance Agda.Termination.Order.NotWorse Agda.Termination.Order.Order
instance (GHC.Classes.Ord i, Agda.Termination.Semiring.HasZero o, Agda.Termination.Order.NotWorse o) => Agda.Termination.Order.NotWorse (Agda.Termination.SparseMatrix.Matrix i o)
instance Agda.Termination.Semiring.HasZero Agda.Termination.Order.Order
instance Agda.Utils.PartialOrd.PartialOrd Agda.Termination.Order.Order
instance Agda.Syntax.Common.Pretty.Pretty Agda.Termination.Order.Order

module Agda.Termination.CallMatrix

-- | Call matrix indices = function argument indices.
--   
--   Machine integer <a>Int</a> is sufficient, since we cannot index more
--   arguments than we have addresses on our machine.
type ArgumentIndex = Int

-- | Call matrices.
--   
--   A call matrix for a call <tt>f --&gt; g</tt> has dimensions <tt>ar(g)
--   × ar(f)</tt>.
--   
--   Each column corresponds to one formal argument of caller <tt>f</tt>.
--   Each row corresponds to one argument in the call to <tt>g</tt>.
--   
--   In the presence of dot patterns, a call argument can be related to
--   <i>several</i> different formal arguments of <tt>f</tt>.
--   
--   See e.g. <tt>test<i>succeed</i>DotPatternTermination.agda</tt>:
--   
--   <pre>
--   data D : Nat -&gt; Set where
--     cz : D zero
--     c1 : forall n -&gt; D n -&gt; D (suc n)
--     c2 : forall n -&gt; D n -&gt; D n
--   
--   f : forall n -&gt; D n -&gt; Nat
--   f .zero    cz        = zero
--   f .(suc n) (c1  n d) = f n (c2 n d)
--   f n        (c2 .n d) = f n d
--   
--   </pre>
--   
--   Call matrices (without guardedness) are
--   
--   <pre>
--   -1 -1   n &lt; suc n  and       n &lt;  c1 n d
--    ?  =                   c2 n d &lt;= c1 n d
--   
--    = -1   n &lt;= n     and  n &lt; c2 n d
--    ? -1                   d &lt; c2 n d
--   
--   </pre>
--   
--   Here is a part of the original documentation for call matrices (kept
--   for historical reasons):
--   
--   This datatype encodes information about a single recursive function
--   application. The columns of the call matrix stand for <tt>source</tt>
--   function arguments (patterns). The rows of the matrix stand for
--   <tt>target</tt> function arguments. Element <tt>(i, j)</tt> in the
--   matrix should be computed as follows:
--   
--   <ul>
--   <li><a>lt</a> (less than) if the <tt>j</tt>-th argument to the
--   <tt>target</tt> function is structurally strictly smaller than the
--   <tt>i</tt>-th pattern.</li>
--   <li><a>le</a> (less than or equal) if the <tt>j</tt>-th argument to
--   the <tt>target</tt> function is structurally smaller than the
--   <tt>i</tt>-th pattern.</li>
--   <li><a>unknown</a> otherwise.</li>
--   </ul>
newtype CallMatrix' a
CallMatrix :: Matrix ArgumentIndex a -> CallMatrix' a
[mat] :: CallMatrix' a -> Matrix ArgumentIndex a
type CallMatrix = CallMatrix' Order

-- | Call matrix multiplication and call combination.
class CallComb a
(>*<) :: (CallComb a, ?cutoff :: CutOff) => a -> a -> a

-- | Call matrix augmented with path information.
data CallMatrixAug cinfo
CallMatrixAug :: CallMatrix -> cinfo -> CallMatrixAug cinfo

-- | The matrix of the (composed call).
[augCallMatrix] :: CallMatrixAug cinfo -> CallMatrix

-- | Meta info, like call path.
[augCallInfo] :: CallMatrixAug cinfo -> cinfo

-- | Non-augmented call matrix.
noAug :: Monoid cinfo => CallMatrix -> CallMatrixAug cinfo

-- | Sets of incomparable call matrices augmented with path information.
--   Use overloaded <a>Null</a>, <a>empty</a>, <a>singleton</a>,
--   <a>mappend</a>.
newtype CMSet cinfo
CMSet :: Favorites (CallMatrixAug cinfo) -> CMSet cinfo
[cmSet] :: CMSet cinfo -> Favorites (CallMatrixAug cinfo)

-- | Insert into a call matrix set.
insert :: CallMatrixAug cinfo -> CMSet cinfo -> CMSet cinfo

-- | Union two call matrix sets.
union :: CMSet cinfo -> CMSet cinfo -> CMSet cinfo

-- | Convert into a list of augmented call matrices.
toList :: CMSet cinfo -> [CallMatrixAug cinfo]
instance Agda.Utils.PartialOrd.PartialOrd a => Agda.Utils.PartialOrd.PartialOrd (Agda.Termination.CallMatrix.CallMatrix' a)
instance Data.Traversable.Traversable Agda.Termination.CallMatrix.CallMatrix'
instance Data.Foldable.Foldable Agda.Termination.CallMatrix.CallMatrix'
instance GHC.Base.Functor Agda.Termination.CallMatrix.CallMatrix'
instance (Agda.Termination.Semiring.HasZero a, GHC.Show.Show a) => GHC.Show.Show (Agda.Termination.CallMatrix.CallMatrix' a)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.Termination.CallMatrix.CallMatrix' a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Termination.CallMatrix.CallMatrix' a)
instance GHC.Show.Show cinfo => GHC.Show.Show (Agda.Termination.CallMatrix.CallMatrixAug cinfo)
instance GHC.Classes.Eq cinfo => GHC.Classes.Eq (Agda.Termination.CallMatrix.CallMatrixAug cinfo)
instance Agda.Utils.Singleton.Singleton (Agda.Termination.CallMatrix.CallMatrixAug cinfo) (Agda.Termination.CallMatrix.CMSet cinfo)
instance Agda.Utils.Null.Null (Agda.Termination.CallMatrix.CMSet cinfo)
instance GHC.Base.Monoid (Agda.Termination.CallMatrix.CMSet cinfo)
instance GHC.Base.Semigroup (Agda.Termination.CallMatrix.CMSet cinfo)
instance GHC.Show.Show cinfo => GHC.Show.Show (Agda.Termination.CallMatrix.CMSet cinfo)
instance Agda.Termination.Order.NotWorse Agda.Termination.CallMatrix.CallMatrix
instance GHC.Base.Monoid cinfo => Agda.Termination.CallMatrix.CallComb (Agda.Termination.CallMatrix.CMSet cinfo)
instance Agda.Syntax.Common.Pretty.Pretty cinfo => Agda.Syntax.Common.Pretty.Pretty (Agda.Termination.CallMatrix.CMSet cinfo)
instance Agda.Termination.SparseMatrix.Diagonal (Agda.Termination.CallMatrix.CallMatrixAug cinfo) Agda.Termination.Order.Order
instance Agda.Utils.PartialOrd.PartialOrd (Agda.Termination.CallMatrix.CallMatrixAug cinfo)
instance Agda.Termination.Order.NotWorse (Agda.Termination.CallMatrix.CallMatrixAug cinfo)
instance GHC.Base.Monoid cinfo => Agda.Termination.CallMatrix.CallComb (Agda.Termination.CallMatrix.CallMatrixAug cinfo)
instance Agda.Syntax.Common.Pretty.Pretty cinfo => Agda.Syntax.Common.Pretty.Pretty (Agda.Termination.CallMatrix.CallMatrixAug cinfo)
instance Agda.Termination.CallMatrix.CallComb Agda.Termination.CallMatrix.CallMatrix
instance Agda.Syntax.Common.Pretty.Pretty Agda.Termination.CallMatrix.CallMatrix
instance Agda.Termination.Semiring.HasZero a => Agda.Termination.SparseMatrix.Diagonal (Agda.Termination.CallMatrix.CallMatrix' a) a


-- | Call graphs and related concepts, more or less as defined in "A
--   Predicative Analysis of Structural Recursion" by Andreas Abel and
--   Thorsten Altenkirch.
module Agda.Termination.CallGraph

-- | Call graph nodes.
--   
--   Machine integer <a>Int</a> is sufficient, since we cannot index more
--   than we have addresses on our machine.
type Node = Int

-- | Calls are edges in the call graph. It can be labelled with several
--   call matrices if there are several pathes from one function to
--   another.
type Call cinfo = Edge Node (CMSet cinfo)

-- | Make a call with a single matrix.
mkCall :: Node -> Node -> CallMatrix -> cinfo -> Call cinfo

-- | Make a call with empty <tt>cinfo</tt>.
mkCall' :: Monoid cinfo => Node -> Node -> CallMatrix -> Call cinfo

-- | Outgoing node.
source :: Edge n e -> n

-- | Incoming node.
target :: Edge n e -> n
callMatrixSet :: Call cinfo -> CMSet cinfo
(>*<) :: (CallComb a, ?cutoff :: CutOff) => a -> a -> a

-- | A call graph is a set of calls. Every call also has some associated
--   meta information, which should be <a>Monoid</a>al so that the meta
--   information for different calls can be combined when the calls are
--   combined.
newtype CallGraph cinfo
CallGraph :: Graph Node (CMSet cinfo) -> CallGraph cinfo
[theCallGraph] :: CallGraph cinfo -> Graph Node (CMSet cinfo)

-- | Returns all the nodes with incoming edges. Somewhat expensive.
--   <tt>O(e)</tt>.
targetNodes :: CallGraph cinfo -> Set Node
fromList :: Collection el coll => [el] -> coll

-- | Converts a call graph to a list of calls with associated meta
--   information.
toList :: CallGraph cinfo -> [Call cinfo]

-- | Takes the union of two call graphs.
union :: CallGraph cinfo -> CallGraph cinfo -> CallGraph cinfo

-- | Inserts a call into a call graph.
insert :: Node -> Node -> CallMatrix -> cinfo -> CallGraph cinfo -> CallGraph cinfo

-- | Call graph comparison. A graph <tt>cs'</tt> is `<tt>worse'</tt> than
--   <tt>cs</tt> if it has a new edge (call) or a call got worse, which
--   means that one of its elements that was better or equal to <tt>Le</tt>
--   moved a step towards <tt>Un</tt>.
--   
--   A call graph is complete if combining it with itself does not make it
--   any worse. This is sound because of monotonicity: By combining a graph
--   with itself, it can only get worse, but if it does not get worse after
--   one such step, it gets never any worse.
--   
--   <tt><a>complete</a> cs</tt> completes the call graph <tt>cs</tt>. A
--   call graph is complete if it contains all indirect calls; if <tt>f
--   -&gt; g</tt> and <tt>g -&gt; h</tt> are present in the graph, then
--   <tt>f -&gt; h</tt> should also be present.
complete :: (?cutoff :: CutOff) => Monoid cinfo => CallGraph cinfo -> CallGraph cinfo
completionStep :: (?cutoff :: CutOff) => Monoid cinfo => CallGraph cinfo -> CallGraph cinfo -> (CallGraph cinfo, CallGraph cinfo)
instance GHC.Show.Show cinfo => GHC.Show.Show (Agda.Termination.CallGraph.CallGraph cinfo)
instance Agda.Termination.CallGraph.CombineNewOld (Agda.Termination.CallMatrix.CMSet cinfo)
instance Agda.Utils.PartialOrd.PartialOrd a => Agda.Termination.CallGraph.CombineNewOld (Agda.Utils.Favorites.Favorites a)
instance (GHC.Base.Monoid a, Agda.Termination.CallGraph.CombineNewOld a, GHC.Classes.Ord n) => Agda.Termination.CallGraph.CombineNewOld (Agda.Utils.Graph.AdjacencyMap.Unidirectional.Graph n a)
instance Agda.Utils.Null.Null (Agda.Termination.CallGraph.CallGraph cinfo)
instance GHC.Base.Semigroup (Agda.Termination.CallGraph.CallGraph cinfo)
instance GHC.Base.Monoid (Agda.Termination.CallGraph.CallGraph cinfo)
instance Agda.Utils.Singleton.Singleton (Agda.Termination.CallGraph.Call cinfo) (Agda.Termination.CallGraph.CallGraph cinfo)
instance Agda.Utils.Singleton.Collection (Agda.Termination.CallGraph.Call cinfo) (Agda.Termination.CallGraph.CallGraph cinfo)
instance Agda.Syntax.Common.Pretty.Pretty cinfo => Agda.Syntax.Common.Pretty.Pretty (Agda.Termination.CallGraph.CallGraph cinfo)


-- | Termination checker, based on "A Predicative Analysis of Structural
--   Recursion" by Andreas Abel and Thorsten Altenkirch (JFP'01), and "The
--   Size-Change Principle for Program Termination" by Chin Soon Lee, Neil
--   Jones, and Amir Ben-Amram (POPL'01).
module Agda.Termination.Termination

-- | TODO: This comment seems to be partly out of date.
--   
--   <tt><a>terminates</a> cs</tt> checks if the functions represented by
--   <tt>cs</tt> terminate. The call graph <tt>cs</tt> should have one
--   entry (<a>Call</a>) per recursive function application.
--   
--   <tt><a>Right</a> perms</tt> is returned if the functions are
--   size-change terminating.
--   
--   If termination can not be established, then <tt><a>Left</a>
--   problems</tt> is returned instead. Here <tt>problems</tt> contains an
--   indication of why termination cannot be established. See
--   <tt>lexOrder</tt> for further details.
--   
--   Note that this function assumes that all data types are strictly
--   positive.
--   
--   The termination criterion is taken from Jones et al. In the completed
--   call graph, each idempotent call-matrix from a function to itself must
--   have a decreasing argument. Idempotency is wrt. matrix multiplication.
--   
--   This criterion is strictly more liberal than searching for a
--   lexicographic order (and easier to implement, but harder to justify).
terminates :: (Monoid cinfo, ?cutoff :: CutOff) => CallGraph cinfo -> Either cinfo ()
terminatesFilter :: (Monoid cinfo, ?cutoff :: CutOff) => (Node -> Bool) -> CallGraph cinfo -> Either cinfo ()
endos :: [Call cinfo] -> [CallMatrixAug cinfo]

-- | A call <tt>c</tt> is idempotent if it is an endo (<tt><a>source</a> ==
--   <a>target</a></tt>) of order 1. (Endo-calls of higher orders are e.g.
--   argument permutations). We can test idempotency by self-composition.
--   Self-composition <tt>c &gt;*&lt; c</tt> should not make any
--   parameter-argument relation worse.
idempotent :: (?cutoff :: CutOff) => CallMatrixAug cinfo -> Bool


-- | Choice of Unicode or ASCII glyphs.
module Agda.Syntax.Concrete.Glyph

-- | We want to know whether we are allowed to insert unicode characters or
--   not.
data UnicodeOrAscii

-- | <a>true</a>: Unicode characters are allowed.
UnicodeOk :: UnicodeOrAscii

-- | 'false: Stick to ASCII.
AsciiOnly :: UnicodeOrAscii
unsafeSetUnicodeOrAscii :: UnicodeOrAscii -> IO ()

-- | Return the glyph set based on a given (unicode or ascii) glyph mode
specialCharactersForGlyphs :: UnicodeOrAscii -> SpecialCharacters
braces' :: Doc -> Doc
dbraces :: Doc -> Doc
forallQ :: Doc
leftIdiomBrkt :: Doc
rightIdiomBrkt :: Doc
emptyIdiomBrkt :: Doc
arrow :: Doc
lambda :: Doc

-- | Picking the appropriate set of special characters depending on whether
--   we are allowed to use unicode or have to limit ourselves to ascii.
data SpecialCharacters
SpecialCharacters :: (Doc -> Doc) -> Doc -> Doc -> Doc -> Doc -> Doc -> Doc -> SpecialCharacters
[_dbraces] :: SpecialCharacters -> Doc -> Doc
[_lambda] :: SpecialCharacters -> Doc
[_arrow] :: SpecialCharacters -> Doc
[_forallQ] :: SpecialCharacters -> Doc
[_leftIdiomBrkt] :: SpecialCharacters -> Doc
[_rightIdiomBrkt] :: SpecialCharacters -> Doc
[_emptyIdiomBrkt] :: SpecialCharacters -> Doc
instance GHC.Generics.Generic Agda.Syntax.Concrete.Glyph.UnicodeOrAscii
instance GHC.Enum.Bounded Agda.Syntax.Concrete.Glyph.UnicodeOrAscii
instance GHC.Enum.Enum Agda.Syntax.Concrete.Glyph.UnicodeOrAscii
instance GHC.Classes.Eq Agda.Syntax.Concrete.Glyph.UnicodeOrAscii
instance GHC.Show.Show Agda.Syntax.Concrete.Glyph.UnicodeOrAscii
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.Glyph.UnicodeOrAscii
instance Agda.Utils.Boolean.Boolean Agda.Syntax.Concrete.Glyph.UnicodeOrAscii
instance Agda.Utils.Boolean.IsBool Agda.Syntax.Concrete.Glyph.UnicodeOrAscii


-- | This module defines the names of all builtin and primitives used in
--   Agda.
--   
--   See <a>Agda.TypeChecking.Monad.Builtin</a>
module Agda.Syntax.Builtin

-- | Either a <a>BuiltinId</a> or <a>PrimitiveId</a>, used for some
--   lookups.
data SomeBuiltin
BuiltinName :: !BuiltinId -> SomeBuiltin
PrimitiveName :: !PrimitiveId -> SomeBuiltin

-- | The class of types which can be converted to <a>SomeBuiltin</a>.
class IsBuiltin a

-- | Convert this value to a builtin.
someBuiltin :: IsBuiltin a => a -> SomeBuiltin

-- | Get the identifier for this builtin, generally used for error
--   messages.
getBuiltinId :: IsBuiltin a => a -> String

-- | A builtin name, defined by the <tt>BUILTIN</tt> pragma.
data BuiltinId
BuiltinNat :: BuiltinId
BuiltinSuc :: BuiltinId
BuiltinZero :: BuiltinId
BuiltinNatPlus :: BuiltinId
BuiltinNatMinus :: BuiltinId
BuiltinNatTimes :: BuiltinId
BuiltinNatDivSucAux :: BuiltinId
BuiltinNatModSucAux :: BuiltinId
BuiltinNatEquals :: BuiltinId
BuiltinNatLess :: BuiltinId
BuiltinWord64 :: BuiltinId
BuiltinInteger :: BuiltinId
BuiltinIntegerPos :: BuiltinId
BuiltinIntegerNegSuc :: BuiltinId
BuiltinFloat :: BuiltinId
BuiltinChar :: BuiltinId
BuiltinString :: BuiltinId
BuiltinUnit :: BuiltinId
BuiltinUnitUnit :: BuiltinId
BuiltinSigma :: BuiltinId
BuiltinSigmaCon :: BuiltinId
BuiltinBool :: BuiltinId
BuiltinTrue :: BuiltinId
BuiltinFalse :: BuiltinId
BuiltinList :: BuiltinId
BuiltinNil :: BuiltinId
BuiltinCons :: BuiltinId
BuiltinMaybe :: BuiltinId
BuiltinNothing :: BuiltinId
BuiltinJust :: BuiltinId
BuiltinIO :: BuiltinId
BuiltinId :: BuiltinId
BuiltinReflId :: BuiltinId
BuiltinPath :: BuiltinId
BuiltinPathP :: BuiltinId
BuiltinIntervalUniv :: BuiltinId
BuiltinInterval :: BuiltinId
BuiltinIZero :: BuiltinId
BuiltinIOne :: BuiltinId
BuiltinPartial :: BuiltinId
BuiltinPartialP :: BuiltinId
BuiltinIsOne :: BuiltinId
BuiltinItIsOne :: BuiltinId
BuiltinEquiv :: BuiltinId
BuiltinEquivFun :: BuiltinId
BuiltinEquivProof :: BuiltinId
BuiltinTranspProof :: BuiltinId
BuiltinIsOne1 :: BuiltinId
BuiltinIsOne2 :: BuiltinId
BuiltinIsOneEmpty :: BuiltinId
BuiltinSub :: BuiltinId
BuiltinSubIn :: BuiltinId
BuiltinSizeUniv :: BuiltinId
BuiltinSize :: BuiltinId
BuiltinSizeLt :: BuiltinId
BuiltinSizeSuc :: BuiltinId
BuiltinSizeInf :: BuiltinId
BuiltinSizeMax :: BuiltinId
BuiltinInf :: BuiltinId
BuiltinSharp :: BuiltinId
BuiltinFlat :: BuiltinId
BuiltinEquality :: BuiltinId
BuiltinRefl :: BuiltinId
BuiltinRewrite :: BuiltinId
BuiltinLevelMax :: BuiltinId
BuiltinLevel :: BuiltinId
BuiltinLevelZero :: BuiltinId
BuiltinLevelSuc :: BuiltinId
BuiltinProp :: BuiltinId
BuiltinSet :: BuiltinId
BuiltinStrictSet :: BuiltinId
BuiltinPropOmega :: BuiltinId
BuiltinSetOmega :: BuiltinId
BuiltinSSetOmega :: BuiltinId
BuiltinLevelUniv :: BuiltinId
BuiltinFromNat :: BuiltinId
BuiltinFromNeg :: BuiltinId
BuiltinFromString :: BuiltinId
BuiltinQName :: BuiltinId
BuiltinAgdaSort :: BuiltinId
BuiltinAgdaSortSet :: BuiltinId
BuiltinAgdaSortLit :: BuiltinId
BuiltinAgdaSortProp :: BuiltinId
BuiltinAgdaSortPropLit :: BuiltinId
BuiltinAgdaSortInf :: BuiltinId
BuiltinAgdaSortUnsupported :: BuiltinId
BuiltinHiding :: BuiltinId
BuiltinHidden :: BuiltinId
BuiltinInstance :: BuiltinId
BuiltinVisible :: BuiltinId
BuiltinRelevance :: BuiltinId
BuiltinRelevant :: BuiltinId
BuiltinIrrelevant :: BuiltinId
BuiltinQuantity :: BuiltinId
BuiltinQuantity0 :: BuiltinId
BuiltinQuantityω :: BuiltinId
BuiltinModality :: BuiltinId
BuiltinModalityConstructor :: BuiltinId
BuiltinAssoc :: BuiltinId
BuiltinAssocLeft :: BuiltinId
BuiltinAssocRight :: BuiltinId
BuiltinAssocNon :: BuiltinId
BuiltinPrecedence :: BuiltinId
BuiltinPrecRelated :: BuiltinId
BuiltinPrecUnrelated :: BuiltinId
BuiltinFixity :: BuiltinId
BuiltinFixityFixity :: BuiltinId
BuiltinArg :: BuiltinId
BuiltinArgInfo :: BuiltinId
BuiltinArgArgInfo :: BuiltinId
BuiltinArgArg :: BuiltinId
BuiltinAbs :: BuiltinId
BuiltinAbsAbs :: BuiltinId
BuiltinAgdaTerm :: BuiltinId
BuiltinAgdaTermVar :: BuiltinId
BuiltinAgdaTermLam :: BuiltinId
BuiltinAgdaTermExtLam :: BuiltinId
BuiltinAgdaTermDef :: BuiltinId
BuiltinAgdaTermCon :: BuiltinId
BuiltinAgdaTermPi :: BuiltinId
BuiltinAgdaTermSort :: BuiltinId
BuiltinAgdaTermLit :: BuiltinId
BuiltinAgdaTermUnsupported :: BuiltinId
BuiltinAgdaTermMeta :: BuiltinId
BuiltinAgdaErrorPart :: BuiltinId
BuiltinAgdaErrorPartString :: BuiltinId
BuiltinAgdaErrorPartTerm :: BuiltinId
BuiltinAgdaErrorPartPatt :: BuiltinId
BuiltinAgdaErrorPartName :: BuiltinId
BuiltinAgdaLiteral :: BuiltinId
BuiltinAgdaLitNat :: BuiltinId
BuiltinAgdaLitWord64 :: BuiltinId
BuiltinAgdaLitFloat :: BuiltinId
BuiltinAgdaLitChar :: BuiltinId
BuiltinAgdaLitString :: BuiltinId
BuiltinAgdaLitQName :: BuiltinId
BuiltinAgdaLitMeta :: BuiltinId
BuiltinAgdaClause :: BuiltinId
BuiltinAgdaClauseClause :: BuiltinId
BuiltinAgdaClauseAbsurd :: BuiltinId
BuiltinAgdaPattern :: BuiltinId
BuiltinAgdaPatVar :: BuiltinId
BuiltinAgdaPatCon :: BuiltinId
BuiltinAgdaPatDot :: BuiltinId
BuiltinAgdaPatLit :: BuiltinId
BuiltinAgdaPatProj :: BuiltinId
BuiltinAgdaPatAbsurd :: BuiltinId
BuiltinAgdaDefinitionFunDef :: BuiltinId
BuiltinAgdaDefinitionDataDef :: BuiltinId
BuiltinAgdaDefinitionRecordDef :: BuiltinId
BuiltinAgdaDefinitionDataConstructor :: BuiltinId
BuiltinAgdaDefinitionPostulate :: BuiltinId
BuiltinAgdaDefinitionPrimitive :: BuiltinId
BuiltinAgdaDefinition :: BuiltinId
BuiltinAgdaMeta :: BuiltinId
BuiltinAgdaTCM :: BuiltinId
BuiltinAgdaTCMReturn :: BuiltinId
BuiltinAgdaTCMBind :: BuiltinId
BuiltinAgdaTCMUnify :: BuiltinId
BuiltinAgdaTCMTypeError :: BuiltinId
BuiltinAgdaTCMInferType :: BuiltinId
BuiltinAgdaTCMCheckType :: BuiltinId
BuiltinAgdaTCMNormalise :: BuiltinId
BuiltinAgdaTCMReduce :: BuiltinId
BuiltinAgdaTCMCatchError :: BuiltinId
BuiltinAgdaTCMGetContext :: BuiltinId
BuiltinAgdaTCMExtendContext :: BuiltinId
BuiltinAgdaTCMInContext :: BuiltinId
BuiltinAgdaTCMFreshName :: BuiltinId
BuiltinAgdaTCMDeclareDef :: BuiltinId
BuiltinAgdaTCMDeclarePostulate :: BuiltinId
BuiltinAgdaTCMDeclareData :: BuiltinId
BuiltinAgdaTCMDefineData :: BuiltinId
BuiltinAgdaTCMDefineFun :: BuiltinId
BuiltinAgdaTCMGetType :: BuiltinId
BuiltinAgdaTCMGetDefinition :: BuiltinId
BuiltinAgdaTCMBlock :: BuiltinId
BuiltinAgdaTCMCommit :: BuiltinId
BuiltinAgdaTCMQuoteTerm :: BuiltinId
BuiltinAgdaTCMUnquoteTerm :: BuiltinId
BuiltinAgdaTCMQuoteOmegaTerm :: BuiltinId
BuiltinAgdaTCMIsMacro :: BuiltinId
BuiltinAgdaTCMWithNormalisation :: BuiltinId
BuiltinAgdaTCMWithReconstructed :: BuiltinId
BuiltinAgdaTCMWithExpandLast :: BuiltinId
BuiltinAgdaTCMWithReduceDefs :: BuiltinId
BuiltinAgdaTCMAskNormalisation :: BuiltinId
BuiltinAgdaTCMAskReconstructed :: BuiltinId
BuiltinAgdaTCMAskExpandLast :: BuiltinId
BuiltinAgdaTCMAskReduceDefs :: BuiltinId
BuiltinAgdaTCMFormatErrorParts :: BuiltinId
BuiltinAgdaTCMDebugPrint :: BuiltinId
BuiltinAgdaTCMNoConstraints :: BuiltinId
BuiltinAgdaTCMWorkOnTypes :: BuiltinId
BuiltinAgdaTCMRunSpeculative :: BuiltinId
BuiltinAgdaTCMExec :: BuiltinId
BuiltinAgdaTCMGetInstances :: BuiltinId
BuiltinAgdaTCMSolveInstances :: BuiltinId
BuiltinAgdaTCMPragmaForeign :: BuiltinId
BuiltinAgdaTCMPragmaCompile :: BuiltinId
BuiltinAgdaBlocker :: BuiltinId
BuiltinAgdaBlockerAny :: BuiltinId
BuiltinAgdaBlockerAll :: BuiltinId
BuiltinAgdaBlockerMeta :: BuiltinId

-- | Builtins that come without a definition in Agda syntax. These are
--   giving names to Agda internal concepts which cannot be assigned an
--   Agda type.
--   
--   An example would be a user-defined name for <tt>Set</tt>.
--   
--   {-# BUILTIN TYPE Type #-}
--   
--   The type of <tt>Type</tt> would be <tt>Type : Level → Setω</tt> which
--   is not valid Agda.
isBuiltinNoDef :: BuiltinId -> Bool
builtinsNoDef :: [BuiltinId]
sizeBuiltins :: [BuiltinId]
builtinNat :: BuiltinId
builtinSuc :: BuiltinId
builtinZero :: BuiltinId
builtinNatPlus :: BuiltinId
builtinNatMinus :: BuiltinId
builtinNatTimes :: BuiltinId
builtinNatDivSucAux :: BuiltinId
builtinNatModSucAux :: BuiltinId
builtinNatEquals :: BuiltinId
builtinNatLess :: BuiltinId
builtinInteger :: BuiltinId
builtinIntegerPos :: BuiltinId
builtinIntegerNegSuc :: BuiltinId
builtinWord64 :: BuiltinId
builtinFloat :: BuiltinId
builtinChar :: BuiltinId
builtinString :: BuiltinId
builtinUnit :: BuiltinId
builtinUnitUnit :: BuiltinId
builtinSigma :: BuiltinId
builtinBool :: BuiltinId
builtinTrue :: BuiltinId
builtinFalse :: BuiltinId
builtinList :: BuiltinId
builtinNil :: BuiltinId
builtinCons :: BuiltinId
builtinIO :: BuiltinId
builtinMaybe :: BuiltinId
builtinNothing :: BuiltinId
builtinJust :: BuiltinId
builtinPath :: BuiltinId
builtinPathP :: BuiltinId
builtinInterval :: BuiltinId
builtinIZero :: BuiltinId
builtinIOne :: BuiltinId
builtinPartial :: BuiltinId
builtinPartialP :: BuiltinId
builtinIsOne :: BuiltinId
builtinItIsOne :: BuiltinId
builtinIsOne1 :: BuiltinId
builtinIsOne2 :: BuiltinId
builtinIsOneEmpty :: BuiltinId
builtinSub :: BuiltinId
builtinSubIn :: BuiltinId
builtinEquiv :: BuiltinId
builtinEquivFun :: BuiltinId
builtinEquivProof :: BuiltinId
builtinTranspProof :: BuiltinId
builtinId :: BuiltinId
builtinReflId :: BuiltinId
builtinSizeUniv :: BuiltinId
builtinSize :: BuiltinId
builtinSizeLt :: BuiltinId
builtinSizeSuc :: BuiltinId
builtinSizeInf :: BuiltinId
builtinSizeMax :: BuiltinId
builtinInf :: BuiltinId
builtinSharp :: BuiltinId
builtinFlat :: BuiltinId
builtinEquality :: BuiltinId
builtinRefl :: BuiltinId
builtinRewrite :: BuiltinId
builtinLevelMax :: BuiltinId
builtinLevel :: BuiltinId
builtinLevelZero :: BuiltinId
builtinLevelSuc :: BuiltinId
builtinProp :: BuiltinId
builtinSet :: BuiltinId
builtinStrictSet :: BuiltinId
builtinPropOmega :: BuiltinId
builtinSetOmega :: BuiltinId
builtinSSetOmega :: BuiltinId
builtinLevelUniv :: BuiltinId
builtinIntervalUniv :: BuiltinId
builtinFromNat :: BuiltinId
builtinFromNeg :: BuiltinId
builtinFromString :: BuiltinId
builtinQName :: BuiltinId
builtinAgdaSort :: BuiltinId
builtinAgdaSortSet :: BuiltinId
builtinAgdaSortLit :: BuiltinId
builtinAgdaSortProp :: BuiltinId
builtinAgdaSortPropLit :: BuiltinId
builtinAgdaSortInf :: BuiltinId
builtinAgdaSortUnsupported :: BuiltinId
builtinHiding :: BuiltinId
builtinHidden :: BuiltinId
builtinInstance :: BuiltinId
builtinVisible :: BuiltinId
builtinRelevance :: BuiltinId
builtinRelevant :: BuiltinId
builtinIrrelevant :: BuiltinId
builtinQuantity :: BuiltinId
builtinQuantity0 :: BuiltinId
builtinQuantityω :: BuiltinId
builtinModality :: BuiltinId
builtinModalityConstructor :: BuiltinId
builtinAssoc :: BuiltinId
builtinAssocLeft :: BuiltinId
builtinAssocRight :: BuiltinId
builtinAssocNon :: BuiltinId
builtinPrecedence :: BuiltinId
builtinPrecRelated :: BuiltinId
builtinPrecUnrelated :: BuiltinId
builtinFixity :: BuiltinId
builtinFixityFixity :: BuiltinId
builtinArgInfo :: BuiltinId
builtinArgArgInfo :: BuiltinId
builtinArg :: BuiltinId
builtinArgArg :: BuiltinId
builtinAbs :: BuiltinId
builtinAbsAbs :: BuiltinId
builtinAgdaTerm :: BuiltinId
builtinAgdaTermVar :: BuiltinId
builtinAgdaTermLam :: BuiltinId
builtinAgdaTermExtLam :: BuiltinId
builtinAgdaTermDef :: BuiltinId
builtinAgdaTermCon :: BuiltinId
builtinAgdaTermPi :: BuiltinId
builtinAgdaTermSort :: BuiltinId
builtinAgdaTermLit :: BuiltinId
builtinAgdaTermUnsupported :: BuiltinId
builtinAgdaTermMeta :: BuiltinId
builtinAgdaErrorPart :: BuiltinId
builtinAgdaErrorPartString :: BuiltinId
builtinAgdaErrorPartTerm :: BuiltinId
builtinAgdaErrorPartPatt :: BuiltinId
builtinAgdaErrorPartName :: BuiltinId
builtinAgdaLiteral :: BuiltinId
builtinAgdaLitNat :: BuiltinId
builtinAgdaLitWord64 :: BuiltinId
builtinAgdaLitFloat :: BuiltinId
builtinAgdaLitChar :: BuiltinId
builtinAgdaLitString :: BuiltinId
builtinAgdaLitQName :: BuiltinId
builtinAgdaLitMeta :: BuiltinId
builtinAgdaClause :: BuiltinId
builtinAgdaClauseClause :: BuiltinId
builtinAgdaClauseAbsurd :: BuiltinId
builtinAgdaPattern :: BuiltinId
builtinAgdaPatVar :: BuiltinId
builtinAgdaPatCon :: BuiltinId
builtinAgdaPatDot :: BuiltinId
builtinAgdaPatLit :: BuiltinId
builtinAgdaPatProj :: BuiltinId
builtinAgdaPatAbsurd :: BuiltinId
builtinAgdaDefinitionFunDef :: BuiltinId
builtinAgdaDefinitionDataDef :: BuiltinId
builtinAgdaDefinitionRecordDef :: BuiltinId
builtinAgdaDefinitionDataConstructor :: BuiltinId
builtinAgdaDefinitionPostulate :: BuiltinId
builtinAgdaDefinitionPrimitive :: BuiltinId
builtinAgdaDefinition :: BuiltinId
builtinAgdaMeta :: BuiltinId
builtinAgdaTCM :: BuiltinId
builtinAgdaTCMReturn :: BuiltinId
builtinAgdaTCMBind :: BuiltinId
builtinAgdaTCMUnify :: BuiltinId
builtinAgdaTCMTypeError :: BuiltinId
builtinAgdaTCMInferType :: BuiltinId
builtinAgdaTCMCheckType :: BuiltinId
builtinAgdaTCMNormalise :: BuiltinId
builtinAgdaTCMReduce :: BuiltinId
builtinAgdaTCMCatchError :: BuiltinId
builtinAgdaTCMGetContext :: BuiltinId
builtinAgdaTCMExtendContext :: BuiltinId
builtinAgdaTCMInContext :: BuiltinId
builtinAgdaTCMFreshName :: BuiltinId
builtinAgdaTCMDeclareDef :: BuiltinId
builtinAgdaTCMDeclarePostulate :: BuiltinId
builtinAgdaTCMDeclareData :: BuiltinId
builtinAgdaTCMDefineData :: BuiltinId
builtinAgdaTCMDefineFun :: BuiltinId
builtinAgdaTCMGetType :: BuiltinId
builtinAgdaTCMGetDefinition :: BuiltinId
builtinAgdaTCMQuoteTerm :: BuiltinId
builtinAgdaTCMUnquoteTerm :: BuiltinId
builtinAgdaTCMQuoteOmegaTerm :: BuiltinId
builtinAgdaTCMCommit :: BuiltinId
builtinAgdaTCMIsMacro :: BuiltinId
builtinAgdaTCMBlock :: BuiltinId
builtinAgdaBlocker :: BuiltinId
builtinAgdaBlockerAll :: BuiltinId
builtinAgdaBlockerAny :: BuiltinId
builtinAgdaBlockerMeta :: BuiltinId
builtinAgdaTCMFormatErrorParts :: BuiltinId
builtinAgdaTCMDebugPrint :: BuiltinId
builtinAgdaTCMWithNormalisation :: BuiltinId
builtinAgdaTCMWithReconstructed :: BuiltinId
builtinAgdaTCMWithExpandLast :: BuiltinId
builtinAgdaTCMWithReduceDefs :: BuiltinId
builtinAgdaTCMAskNormalisation :: BuiltinId
builtinAgdaTCMAskReconstructed :: BuiltinId
builtinAgdaTCMAskExpandLast :: BuiltinId
builtinAgdaTCMAskReduceDefs :: BuiltinId
builtinAgdaTCMNoConstraints :: BuiltinId
builtinAgdaTCMWorkOnTypes :: BuiltinId
builtinAgdaTCMRunSpeculative :: BuiltinId
builtinAgdaTCMExec :: BuiltinId
builtinAgdaTCMGetInstances :: BuiltinId
builtinAgdaTCMSolveInstances :: BuiltinId
builtinAgdaTCMPragmaForeign :: BuiltinId
builtinAgdaTCMPragmaCompile :: BuiltinId

-- | Lookup a builtin by the string used in the <tt>BUILTIN</tt> pragma.
builtinById :: String -> Maybe BuiltinId

-- | A primitive name, defined by the <tt>primitive</tt> block.
data PrimitiveId
PrimConId :: PrimitiveId
PrimIdElim :: PrimitiveId
PrimIMin :: PrimitiveId
PrimIMax :: PrimitiveId
PrimINeg :: PrimitiveId
PrimPartial :: PrimitiveId
PrimPartialP :: PrimitiveId
PrimSubOut :: PrimitiveId
PrimGlue :: PrimitiveId
Prim_glue :: PrimitiveId
Prim_unglue :: PrimitiveId
Prim_glueU :: PrimitiveId
Prim_unglueU :: PrimitiveId
PrimFaceForall :: PrimitiveId
PrimComp :: PrimitiveId
PrimPOr :: PrimitiveId
PrimTrans :: PrimitiveId
PrimDepIMin :: PrimitiveId
PrimIdFace :: PrimitiveId
PrimIdPath :: PrimitiveId
PrimHComp :: PrimitiveId
PrimShowInteger :: PrimitiveId
PrimNatPlus :: PrimitiveId
PrimNatMinus :: PrimitiveId
PrimNatTimes :: PrimitiveId
PrimNatDivSucAux :: PrimitiveId
PrimNatModSucAux :: PrimitiveId
PrimNatEquality :: PrimitiveId
PrimNatLess :: PrimitiveId
PrimShowNat :: PrimitiveId
PrimWord64FromNat :: PrimitiveId
PrimWord64ToNat :: PrimitiveId
PrimWord64ToNatInjective :: PrimitiveId
PrimLevelZero :: PrimitiveId
PrimLevelSuc :: PrimitiveId
PrimLevelMax :: PrimitiveId
PrimFloatEquality :: PrimitiveId
PrimFloatInequality :: PrimitiveId
PrimFloatLess :: PrimitiveId
PrimFloatIsInfinite :: PrimitiveId
PrimFloatIsNaN :: PrimitiveId
PrimFloatIsNegativeZero :: PrimitiveId
PrimFloatIsSafeInteger :: PrimitiveId
PrimFloatToWord64 :: PrimitiveId
PrimFloatToWord64Injective :: PrimitiveId
PrimNatToFloat :: PrimitiveId
PrimIntToFloat :: PrimitiveId
PrimFloatRound :: PrimitiveId
PrimFloatFloor :: PrimitiveId
PrimFloatCeiling :: PrimitiveId
PrimFloatToRatio :: PrimitiveId
PrimRatioToFloat :: PrimitiveId
PrimFloatDecode :: PrimitiveId
PrimFloatEncode :: PrimitiveId
PrimShowFloat :: PrimitiveId
PrimFloatPlus :: PrimitiveId
PrimFloatMinus :: PrimitiveId
PrimFloatTimes :: PrimitiveId
PrimFloatNegate :: PrimitiveId
PrimFloatDiv :: PrimitiveId
PrimFloatPow :: PrimitiveId
PrimFloatSqrt :: PrimitiveId
PrimFloatExp :: PrimitiveId
PrimFloatLog :: PrimitiveId
PrimFloatSin :: PrimitiveId
PrimFloatCos :: PrimitiveId
PrimFloatTan :: PrimitiveId
PrimFloatASin :: PrimitiveId
PrimFloatACos :: PrimitiveId
PrimFloatATan :: PrimitiveId
PrimFloatATan2 :: PrimitiveId
PrimFloatSinh :: PrimitiveId
PrimFloatCosh :: PrimitiveId
PrimFloatTanh :: PrimitiveId
PrimFloatASinh :: PrimitiveId
PrimFloatACosh :: PrimitiveId
PrimFloatATanh :: PrimitiveId
PrimCharEquality :: PrimitiveId
PrimIsLower :: PrimitiveId
PrimIsDigit :: PrimitiveId
PrimIsAlpha :: PrimitiveId
PrimIsSpace :: PrimitiveId
PrimIsAscii :: PrimitiveId
PrimIsLatin1 :: PrimitiveId
PrimIsPrint :: PrimitiveId
PrimIsHexDigit :: PrimitiveId
PrimToUpper :: PrimitiveId
PrimToLower :: PrimitiveId
PrimCharToNat :: PrimitiveId
PrimCharToNatInjective :: PrimitiveId
PrimNatToChar :: PrimitiveId
PrimShowChar :: PrimitiveId
PrimStringToList :: PrimitiveId
PrimStringToListInjective :: PrimitiveId
PrimStringFromList :: PrimitiveId
PrimStringFromListInjective :: PrimitiveId
PrimStringAppend :: PrimitiveId
PrimStringEquality :: PrimitiveId
PrimShowString :: PrimitiveId
PrimStringUncons :: PrimitiveId
PrimErase :: PrimitiveId
PrimEraseEquality :: PrimitiveId
PrimForce :: PrimitiveId
PrimForceLemma :: PrimitiveId
PrimQNameEquality :: PrimitiveId
PrimQNameLess :: PrimitiveId
PrimShowQName :: PrimitiveId
PrimQNameFixity :: PrimitiveId
PrimQNameToWord64s :: PrimitiveId
PrimQNameToWord64sInjective :: PrimitiveId
PrimMetaEquality :: PrimitiveId
PrimMetaLess :: PrimitiveId
PrimShowMeta :: PrimitiveId
PrimMetaToNat :: PrimitiveId
PrimMetaToNatInjective :: PrimitiveId
PrimLockUniv :: PrimitiveId
builtinConId :: PrimitiveId
builtinIdElim :: PrimitiveId
builtinSubOut :: PrimitiveId
builtinIMin :: PrimitiveId
builtinIMax :: PrimitiveId
builtinINeg :: PrimitiveId
builtinGlue :: PrimitiveId
builtin_glue :: PrimitiveId
builtin_unglue :: PrimitiveId
builtin_glueU :: PrimitiveId
builtin_unglueU :: PrimitiveId
builtinFaceForall :: PrimitiveId
builtinComp :: PrimitiveId
builtinPOr :: PrimitiveId
builtinTrans :: PrimitiveId
builtinDepIMin :: PrimitiveId
builtinIdFace :: PrimitiveId
builtinIdPath :: PrimitiveId
builtinHComp :: PrimitiveId
builtinLockUniv :: PrimitiveId

-- | Lookup a primitive by its identifier.
primitiveById :: String -> Maybe PrimitiveId
instance GHC.Generics.Generic Agda.Syntax.Builtin.BuiltinId
instance GHC.Enum.Enum Agda.Syntax.Builtin.BuiltinId
instance GHC.Enum.Bounded Agda.Syntax.Builtin.BuiltinId
instance GHC.Classes.Ord Agda.Syntax.Builtin.BuiltinId
instance GHC.Classes.Eq Agda.Syntax.Builtin.BuiltinId
instance GHC.Show.Show Agda.Syntax.Builtin.BuiltinId
instance GHC.Generics.Generic Agda.Syntax.Builtin.PrimitiveId
instance GHC.Enum.Enum Agda.Syntax.Builtin.PrimitiveId
instance GHC.Enum.Bounded Agda.Syntax.Builtin.PrimitiveId
instance GHC.Classes.Ord Agda.Syntax.Builtin.PrimitiveId
instance GHC.Classes.Eq Agda.Syntax.Builtin.PrimitiveId
instance GHC.Show.Show Agda.Syntax.Builtin.PrimitiveId
instance GHC.Generics.Generic Agda.Syntax.Builtin.SomeBuiltin
instance GHC.Classes.Ord Agda.Syntax.Builtin.SomeBuiltin
instance GHC.Classes.Eq Agda.Syntax.Builtin.SomeBuiltin
instance GHC.Show.Show Agda.Syntax.Builtin.SomeBuiltin
instance Agda.Syntax.Builtin.IsBuiltin Agda.Syntax.Builtin.SomeBuiltin
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Builtin.BuiltinId
instance Agda.Syntax.Builtin.IsBuiltin Agda.Syntax.Builtin.BuiltinId
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Builtin.PrimitiveId
instance Agda.Syntax.Builtin.IsBuiltin Agda.Syntax.Builtin.PrimitiveId
instance Data.Hashable.Class.Hashable Agda.Syntax.Builtin.SomeBuiltin
instance Control.DeepSeq.NFData Agda.Syntax.Builtin.SomeBuiltin
instance Control.DeepSeq.NFData Agda.Syntax.Builtin.PrimitiveId
instance Data.Hashable.Class.Hashable Agda.Syntax.Builtin.PrimitiveId
instance Agda.Syntax.Position.KillRange Agda.Syntax.Builtin.PrimitiveId
instance Control.DeepSeq.NFData Agda.Syntax.Builtin.BuiltinId
instance Data.Hashable.Class.Hashable Agda.Syntax.Builtin.BuiltinId
instance Agda.Syntax.Position.KillRange Agda.Syntax.Builtin.BuiltinId


-- | Code for instructing Emacs to do things
module Agda.Interaction.EmacsCommand

-- | Simple Emacs Lisp expressions.
data Lisp a

-- | Atom.
A :: a -> Lisp a
Cons :: Lisp a -> Lisp a -> Lisp a

-- | List.
L :: [Lisp a] -> Lisp a
Q :: Lisp a -> Lisp a

-- | Formats a response command.
--   
--   Replaces <tt>'n'</tt> with spaces to ensure that each command is a
--   single line.
response :: Lisp String -> String

-- | Writes a response command to standard output.
putResponse :: Lisp String -> IO ()
display_info' :: Bool -> String -> String -> Lisp String

-- | Clear the running info buffer.
clearRunningInfo :: Lisp String

-- | Clear the warning buffer
clearWarning :: Lisp String

-- | Display running information about what the type-checker is up to.
displayRunningInfo :: String -> Lisp String
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Interaction.EmacsCommand.Lisp a)
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Interaction.EmacsCommand.Lisp a)


-- | A abstract <a>Range'</a> type dedicated to keyword occurrences in the
--   source.
module Agda.Syntax.Common.KeywordRange

-- | Range dedicated to a keyword or fixed token sequence.
--   
--   Motivation: by lacking a <a>SetRange</a> instance we indicate that it
--   cannot be updated.
data KwRange

-- | Create a keyword range.
kwRange :: HasRange a => a -> KwRange
instance Agda.Utils.Null.Null Agda.Syntax.Common.KeywordRange.KwRange
instance GHC.Show.Show Agda.Syntax.Common.KeywordRange.KwRange
instance GHC.Classes.Ord Agda.Syntax.Common.KeywordRange.KwRange
instance GHC.Classes.Eq Agda.Syntax.Common.KeywordRange.KwRange
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.KeywordRange.KwRange
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.KeywordRange.KwRange
instance Control.DeepSeq.NFData Agda.Syntax.Common.KeywordRange.KwRange
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.KeywordRange.KwRange


-- | Some common syntactic entities are defined in this module.
module Agda.Syntax.Common
type Arity = Nat
data Overlappable
YesOverlap :: Overlappable
NoOverlap :: Overlappable
type Nat = Int

-- | Associativity.
data Associativity
NonAssoc :: Associativity
LeftAssoc :: Associativity
RightAssoc :: Associativity

-- | Fixity of operators.
data Fixity
Fixity :: Range -> !FixityLevel -> !Associativity -> Fixity

-- | Range of the whole fixity declaration.
[fixityRange] :: Fixity -> Range
[fixityLevel] :: Fixity -> !FixityLevel
[fixityAssoc] :: Fixity -> !Associativity
newtype Constr a
Constr :: a -> Constr a
data Arg e
Arg :: ArgInfo -> e -> Arg e
[argInfo] :: Arg e -> ArgInfo
[unArg] :: Arg e -> e
data FileType
AgdaFileType :: FileType
MdFileType :: FileType
RstFileType :: FileType
TexFileType :: FileType
OrgFileType :: FileType
TypstFileType :: FileType
data IsMain
IsMain :: IsMain
NotMain :: IsMain
newtype InteractionId
InteractionId :: Nat -> InteractionId
[interactionId] :: InteractionId -> Nat

-- | We have a tuple of modalities, which might not be fully orthogonal.
--   For example, irrelevant stuff is also run-time irrelevant.
data Modality
Modality :: Relevance -> Quantity -> Cohesion -> Modality

-- | Legacy irrelevance. See Pfenning, LiCS 2001; Abel, Vezzosi and
--   Winterhalter, ICFP 2017.
[modRelevance] :: Modality -> Relevance

-- | Cardinality / runtime erasure. See Conor McBride, I got plenty o'
--   nutting, Wadlerfest 2016. See Bob Atkey, Syntax and Semantics of
--   Quantitative Type Theory, LiCS 2018.
[modQuantity] :: Modality -> Quantity

-- | Cohesion/what was in Agda-flat. see "Brouwer's fixed-point theorem in
--   real-cohesive homotopy type theory" (arXiv:1509.07584) Currently only
--   the comonad is implemented.
[modCohesion] :: Modality -> Cohesion

-- | A "problem" consists of a set of constraints and the same constraint
--   can be part of multiple problems.
newtype ProblemId
ProblemId :: Nat -> ProblemId

-- | Meta-variable identifiers use the same structure as <a>NameId</a>s.
data MetaId
MetaId :: {-# UNPACK #-} !Word64 -> {-# UNPACK #-} !ModuleNameHash -> MetaId
[metaId] :: MetaId -> {-# UNPACK #-} !Word64
[metaModule] :: MetaId -> {-# UNPACK #-} !ModuleNameHash

-- | Thing with range info.
data Ranged a
Ranged :: Range -> a -> Ranged a
[rangeOf] :: Ranged a -> Range
[rangedThing] :: Ranged a -> a

-- | A function argument can be hidden and/or irrelevant.
data ArgInfo
ArgInfo :: Hiding -> Modality -> Origin -> FreeVariables -> Annotation -> ArgInfo
[argInfoHiding] :: ArgInfo -> Hiding
[argInfoModality] :: ArgInfo -> Modality
[argInfoOrigin] :: ArgInfo -> Origin
[argInfoFreeVariables] :: ArgInfo -> FreeVariables

-- | Sometimes we want a different kind of binder/pi-type, without it
--   supporting any of the <tt>Modality</tt> interface.
[argInfoAnnotation] :: ArgInfo -> Annotation

-- | Origin of arguments.
data Origin

-- | From the source file / user input. (Preserve!)
UserWritten :: Origin

-- | E.g. inserted hidden arguments.
Inserted :: Origin

-- | Produced by the reflection machinery.
Reflected :: Origin

-- | Produced by an interactive case split.
CaseSplit :: Origin

-- | Named application produced to represent a substitution. E.g. "?0 (x =
--   n)" instead of "?0 n"
Substitution :: Origin

-- | An expanded hidden argument pun.
ExpandedPun :: Origin

-- | Inserted by the generalization process
Generalization :: Origin

-- | Where does the <tt>ConP</tt> or <tt>Con</tt> come from?
data ConOrigin

-- | Inserted by system or expanded from an implicit pattern.
ConOSystem :: ConOrigin

-- | User wrote a constructor (pattern).
ConOCon :: ConOrigin

-- | User wrote a record (pattern).
ConORec :: ConOrigin

-- | Generated by interactive case splitting.
ConOSplit :: ConOrigin
data Hiding
Hidden :: Hiding
Instance :: Overlappable -> Hiding
NotHidden :: Hiding

-- | The unique identifier of a name. Second argument is the top-level
--   module identifier.
data NameId
NameId :: {-# UNPACK #-} !Word64 -> {-# UNPACK #-} !ModuleNameHash -> NameId

-- | Where does a projection come from?
data ProjOrigin

-- | User wrote a prefix projection.
ProjPrefix :: ProjOrigin

-- | User wrote a postfix projection.
ProjPostfix :: ProjOrigin

-- | Projection was generated by the system.
ProjSystem :: ProjOrigin

-- | Termination check? (Default = TerminationCheck).
data TerminationCheck m

-- | Run the termination checker.
TerminationCheck :: TerminationCheck m

-- | Skip termination checking (unsafe).
NoTerminationCheck :: TerminationCheck m

-- | Treat as non-terminating.
NonTerminating :: TerminationCheck m

-- | Treat as terminating (unsafe). Same effect as
--   <a>NoTerminationCheck</a>.
Terminating :: TerminationCheck m

-- | Skip termination checking but use measure instead.
TerminationMeasure :: Range -> m -> TerminationCheck m

-- | Notation as provided by the <tt>syntax</tt> declaration.
type Notation = [NotationPart]
data Lock
IsNotLock :: Lock

-- | In the future there might be different kinds of them. For now we
--   assume lock weakening.
IsLock :: LockOrigin -> Lock

-- | Variants of Cubical Agda.
data Cubical
CErased :: Cubical
CFull :: Cubical

-- | Only <a>Hidden</a> arguments can have names.
type NamedArg a = Arg (Named_ a)

-- | Opaque or transparent.
data IsOpaque

-- | This definition is opaque, and it is guarded by the given opaque
--   block.
OpaqueDef :: {-# UNPACK #-} !OpaqueId -> IsOpaque
TransparentDef :: IsOpaque

-- | An imported name can be a module or a defined name.
data ImportedName' n m

-- | Imported module name of type <tt>m</tt>.
ImportedModule :: m -> ImportedName' n m

-- | Imported name of type <tt>n</tt>.
ImportedName :: n -> ImportedName' n m

-- | A function argument can be relevant or irrelevant. See
--   <a>Agda.TypeChecking.Irrelevance</a>.
data Relevance

-- | The argument is (possibly) relevant at compile-time.
Relevant :: Relevance

-- | The argument may never flow into evaluation position. Therefore, it is
--   irrelevant at run-time. It is treated relevantly during equality
--   checking.
--   
--   The above comment is probably obsolete, as we currently have erasure
--   (<i>at</i>0, <tt>Quantity0</tt>) for that. What's described here is
--   probably shape-irrelevance (..). If you enable
--   <tt>--experimental-irrelevance</tt>, then the type of an irrelevant
--   function is forced to be shape-irrelevant. See: -
--   <a>https://doi.org/10.2168/LMCS-8(1:29)2012</a> example 2.8 (Not
--   enforcing shape-irrelevant codomains can break subject reduction!) -
--   <a>https://dl.acm.org/doi/10.1145/3110277</a> -
--   <a>https://doi.org/10.1145/3209108.3209119</a>
NonStrict :: Relevance

-- | The argument is irrelevant at compile- and runtime.
Irrelevant :: Relevance

-- | Decorating something with <a>Hiding</a> information.
data WithHiding a
WithHiding :: !Hiding -> a -> WithHiding a
[whHiding] :: WithHiding a -> !Hiding
[whThing] :: WithHiding a -> a

-- | Agda variants.
--   
--   Only some variants are tracked.
data Language
WithoutK :: Language
WithK :: Language
Cubical :: Cubical -> Language
data RecordDirectives' a
RecordDirectives :: Maybe (Ranged Induction) -> Maybe (Ranged HasEta0) -> Maybe Range -> Maybe a -> RecordDirectives' a
[recInductive] :: RecordDirectives' a -> Maybe (Ranged Induction)
[recHasEta] :: RecordDirectives' a -> Maybe (Ranged HasEta0)
[recPattern] :: RecordDirectives' a -> Maybe Range
[recConstructor] :: RecordDirectives' a -> Maybe a
type HasEta0 = HasEta' ()

-- | Does a record come with eta-equality?
data HasEta' a
YesEta :: HasEta' a
NoEta :: a -> HasEta' a

-- | Pattern and copattern matching is allowed in the presence of eta.
--   
--   In the absence of eta, we have to choose whether we want to allow
--   matching on the constructor or copattern matching with the
--   projections. Having both leads to breakage of subject reduction (issue
--   #4560).
type HasEta = HasEta' PatternOrCopattern

-- | For a record without eta, which type of matching do we allow?
data PatternOrCopattern

-- | Can match on the record constructor.
PatternMatching :: PatternOrCopattern

-- | Can copattern match using the projections. (Default.)
CopatternMatching :: PatternOrCopattern

-- | Can we pattern match on the record constructor?
class PatternMatchingAllowed a
patternMatchingAllowed :: PatternMatchingAllowed a => a -> Bool

-- | Can we construct a record by copattern matching?
class CopatternMatchingAllowed a
copatternMatchingAllowed :: CopatternMatchingAllowed a => a -> Bool

-- | The possible overlap modes for an instance, also used for instance
--   candidates.
data OverlapMode

-- | User-written OVERLAPPABLE pragma: this candidate can *be removed* by a
--   more specific candidate.
Overlappable :: OverlapMode

-- | User-written OVERLAPPING pragma: this candidate can *remove* a less
--   specific candidate.
Overlapping :: OverlapMode

-- | User-written OVERLAPS pragma: both overlappable and overlapping.
Overlaps :: OverlapMode

-- | No user-written overlap pragma. This instance can be overlapped by an
--   OVERLAPPING instance, and it can overlap OVERLAPPABLE instances.
DefaultOverlap :: OverlapMode

-- | User-written INCOHERENT pragma: both overlappable and overlapping;
--   and, if there are multiple candidates after all overlap has been
--   handled, make an arbitrary choice.
Incoherent :: OverlapMode

-- | Overlapping instances in record fields.
FieldOverlap :: OverlapMode
class HasOverlapMode a
lensOverlapMode :: HasOverlapMode a => Lens' a OverlapMode

-- | A lens to access the <a>Hiding</a> attribute in data structures.
--   Minimal implementation: <tt>getHiding</tt> and <tt>mapHiding</tt> or
--   <tt>LensArgInfo</tt>.
class LensHiding a
getHiding :: LensHiding a => a -> Hiding
setHiding :: LensHiding a => Hiding -> a -> a
mapHiding :: LensHiding a => (Hiding -> Hiding) -> a -> a
getHiding :: (LensHiding a, LensArgInfo a) => a -> Hiding
mapHiding :: (LensHiding a, LensArgInfo a) => (Hiding -> Hiding) -> a -> a
class LensArgInfo a
getArgInfo :: LensArgInfo a => a -> ArgInfo
setArgInfo :: LensArgInfo a => ArgInfo -> a -> a
mapArgInfo :: LensArgInfo a => (ArgInfo -> ArgInfo) -> a -> a

-- | Something potentially carrying a name.
data Named name a
Named :: Maybe name -> a -> Named name a
[nameOf] :: Named name a -> Maybe name
[namedThing] :: Named name a -> a

-- | Type wrapper to indicate additive monoid/semigroup context.
newtype UnderAddition t
UnderAddition :: t -> UnderAddition t

-- | Type wrapper to indicate composition or multiplicative
--   monoid/semigroup context.
newtype UnderComposition t
UnderComposition :: t -> UnderComposition t

-- | Quantity for linearity.
--   
--   A quantity is a set of natural numbers, indicating possible semantic
--   uses of a variable. A singleton set <tt>{n}</tt> requires that the
--   corresponding variable is used exactly <tt>n</tt> times.
data Quantity

-- | Zero uses <tt>{0}</tt>, erased at runtime.
Quantity0 :: Q0Origin -> Quantity

-- | Linear use <tt>{1}</tt> (could be updated destructively). Mostly TODO
--   (needs postponable constraints between quantities to compute uses).
Quantity1 :: Q1Origin -> Quantity

-- | Unrestricted use <tt>ℕ</tt>.
Quantityω :: QωOrigin -> Quantity

-- | Cohesion modalities see "Brouwer's fixed-point theorem in
--   real-cohesive homotopy type theory" (arXiv:1509.07584) types are now
--   given an additional topological layer which the modalities interact
--   with.
data Cohesion

-- | same points, discrete topology, idempotent comonad, box-like.
Flat :: Cohesion

-- | identity modality. | Sharp -- ^ same points, codiscrete topology,
--   idempotent monad, diamond-like.
Continuous :: Cohesion

-- | single point space, artificially added for Flat left-composition.
Squash :: Cohesion
class LensModality a
getModality :: LensModality a => a -> Modality
setModality :: LensModality a => Modality -> a -> a
mapModality :: LensModality a => (Modality -> Modality) -> a -> a
getModality :: (LensModality a, LensArgInfo a) => a -> Modality
mapModality :: (LensModality a, LensArgInfo a) => (Modality -> Modality) -> a -> a

-- | A lens to access the <a>Relevance</a> attribute in data structures.
--   Minimal implementation: <tt>getRelevance</tt> and
--   <tt>mapRelevance</tt> or <tt>LensModality</tt>.
class LensRelevance a
getRelevance :: LensRelevance a => a -> Relevance
setRelevance :: LensRelevance a => Relevance -> a -> a
mapRelevance :: LensRelevance a => (Relevance -> Relevance) -> a -> a
getRelevance :: (LensRelevance a, LensModality a) => a -> Relevance
mapRelevance :: (LensRelevance a, LensModality a) => (Relevance -> Relevance) -> a -> a
class LensQuantity a
getQuantity :: LensQuantity a => a -> Quantity
setQuantity :: LensQuantity a => Quantity -> a -> a
mapQuantity :: LensQuantity a => (Quantity -> Quantity) -> a -> a
getQuantity :: (LensQuantity a, LensModality a) => a -> Quantity
mapQuantity :: (LensQuantity a, LensModality a) => (Quantity -> Quantity) -> a -> a

-- | A lens to access the <a>Cohesion</a> attribute in data structures.
--   Minimal implementation: <tt>getCohesion</tt> and <tt>mapCohesion</tt>
--   or <tt>LensModality</tt>.
class LensCohesion a
getCohesion :: LensCohesion a => a -> Cohesion
setCohesion :: LensCohesion a => Cohesion -> a -> a
mapCohesion :: LensCohesion a => (Cohesion -> Cohesion) -> a -> a
getCohesion :: (LensCohesion a, LensModality a) => a -> Cohesion
mapCohesion :: (LensCohesion a, LensModality a) => (Cohesion -> Cohesion) -> a -> a

-- | Origin of <a>Quantity0</a>.
data Q0Origin

-- | User wrote nothing.
Q0Inferred :: Q0Origin

-- | User wrote "@0".
Q0 :: Range -> Q0Origin

-- | User wrote "@erased".
Q0Erased :: Range -> Q0Origin

-- | Origin of <a>Quantity1</a>.
data Q1Origin

-- | User wrote nothing.
Q1Inferred :: Q1Origin

-- | User wrote "@1".
Q1 :: Range -> Q1Origin

-- | User wrote "@linear".
Q1Linear :: Range -> Q1Origin

-- | Origin of <a>Quantityω</a>.
data QωOrigin

-- | User wrote nothing.
QωInferred :: QωOrigin

-- | User wrote "@ω".
Qω :: Range -> QωOrigin

-- | User wrote "@plenty".
QωPlenty :: Range -> QωOrigin

-- | A special case of <a>Quantity</a>: erased or not.
--   
--   Note that the <a>Ord</a> instance does *not* ignore the origin
--   arguments.
data Erased
Erased :: Q0Origin -> Erased
NotErased :: QωOrigin -> Erased

-- | We have a tuple of annotations, which might not be fully orthogonal.
data Annotation
Annotation :: Lock -> Annotation

-- | Fitch-style dependent right adjoints. See Modal Dependent Type Theory
--   and Dependent Right Adjoints, arXiv:1804.05236.
[annLock] :: Annotation -> Lock
class LensAnnotation a
getAnnotation :: LensAnnotation a => a -> Annotation
setAnnotation :: LensAnnotation a => Annotation -> a -> a
mapAnnotation :: LensAnnotation a => (Annotation -> Annotation) -> a -> a
getAnnotation :: (LensAnnotation a, LensArgInfo a) => a -> Annotation
setAnnotation :: (LensAnnotation a, LensArgInfo a) => Annotation -> a -> a
data LockOrigin

-- | The user wrote @lock.
LockOLock :: LockOrigin

-- | The user wrote @tick.
LockOTick :: LockOrigin
class LensLock a
getLock :: LensLock a => a -> Lock
setLock :: LensLock a => Lock -> a -> a
mapLock :: LensLock a => (Lock -> Lock) -> a -> a

-- | Decorating something with <a>Origin</a> information.
data WithOrigin a
WithOrigin :: !Origin -> a -> WithOrigin a
[woOrigin] :: WithOrigin a -> !Origin
[woThing] :: WithOrigin a -> a

-- | A lens to access the <a>Origin</a> attribute in data structures.
--   Minimal implementation: <tt>getOrigin</tt> and <tt>mapOrigin</tt> or
--   <tt>LensArgInfo</tt>.
class LensOrigin a
getOrigin :: LensOrigin a => a -> Origin
setOrigin :: LensOrigin a => Origin -> a -> a
mapOrigin :: LensOrigin a => (Origin -> Origin) -> a -> a
getOrigin :: (LensOrigin a, LensArgInfo a) => a -> Origin
mapOrigin :: (LensOrigin a, LensArgInfo a) => (Origin -> Origin) -> a -> a
data FreeVariables
UnknownFVs :: FreeVariables
KnownFVs :: IntSet -> FreeVariables

-- | A lens to access the <a>FreeVariables</a> attribute in data
--   structures. Minimal implementation: <tt>getFreeVariables</tt> and
--   <tt>mapFreeVariables</tt> or <tt>LensArgInfo</tt>.
class LensFreeVariables a
getFreeVariables :: LensFreeVariables a => a -> FreeVariables
setFreeVariables :: LensFreeVariables a => FreeVariables -> a -> a
mapFreeVariables :: LensFreeVariables a => (FreeVariables -> FreeVariables) -> a -> a
getFreeVariables :: (LensFreeVariables a, LensArgInfo a) => a -> FreeVariables
mapFreeVariables :: (LensFreeVariables a, LensArgInfo a) => (FreeVariables -> FreeVariables) -> a -> a
class Eq a => Underscore a
underscore :: Underscore a => a
isUnderscore :: Underscore a => a -> Bool

-- | Standard naming.
type Named_ = Named NamedName

-- | Standard argument names.
type NamedName = WithOrigin (Ranged ArgName)

-- | Names in binders and arguments.
type ArgName = String

-- | Accessor/editor for the <a>nameOf</a> component.
class LensNamed a where {
    
    -- | The type of the name
    type NameOf a;
}
lensNamed :: LensNamed a => Lens' a (Maybe (NameOf a))
lensNamed :: (LensNamed a, Decoration f, LensNamed b, NameOf b ~ NameOf a, f b ~ a) => Lens' a (Maybe (NameOf a))

-- | A <tt>RawName</tt> is some sort of string.
type RawName = String

-- | String with range info.
type RString = Ranged RawName

-- | Functions can be defined in both infix and prefix style. See
--   <a>LHS</a>.
data IsInfix
InfixDef :: IsInfix
PrefixDef :: IsInfix

-- | Access modifier.
data Access

-- | Store the <a>Origin</a> of the private block that lead to this
--   qualifier. This is needed for more faithful printing of declarations.
--   <a>KwRange</a> is the range of the <tt>private</tt> keyword.
PrivateAccess :: KwRange -> Origin -> Access
PublicAccess :: Access

-- | Abstract or concrete.
data IsAbstract
AbstractDef :: IsAbstract
ConcreteDef :: IsAbstract
class LensIsAbstract a
lensIsAbstract :: LensIsAbstract a => Lens' a IsAbstract

-- | Is any element of a collection an <a>AbstractDef</a>.
class AnyIsAbstract a
anyIsAbstract :: AnyIsAbstract a => a -> IsAbstract
anyIsAbstract :: (AnyIsAbstract a, Foldable t, AnyIsAbstract b, t b ~ a) => a -> IsAbstract

-- | Is this definition eligible for instance search?
data IsInstance

-- | Range of the <tt>instance</tt> keyword.
InstanceDef :: KwRange -> IsInstance
NotInstanceDef :: IsInstance

-- | Is this a macro definition?
data IsMacro
MacroDef :: IsMacro
NotMacroDef :: IsMacro

-- | The unique identifier of an opaque block. Second argument is the
--   top-level module identifier.
data OpaqueId
OpaqueId :: {-# UNPACK #-} !Word64 -> {-# UNPACK #-} !ModuleNameHash -> OpaqueId
class LensIsOpaque a
lensIsOpaque :: LensIsOpaque a => Lens' a IsOpaque

-- | Monoid representing the combined opaque blocks of a <a>Foldable</a>
--   containing possibly-opaque declarations.
data JointOpacity

-- | Every definition agrees on what opaque block they belong to.
UniqueOpaque :: {-# UNPACK #-} !OpaqueId -> JointOpacity

-- | More than one opaque block was found.
DifferentOpaque :: !HashSet OpaqueId -> JointOpacity

-- | Nothing here is opaque.
NoOpaque :: JointOpacity
class AllAreOpaque a
jointOpacity :: AllAreOpaque a => a -> JointOpacity
jointOpacity :: (AllAreOpaque a, Foldable t, AllAreOpaque b, t b ~ a) => a -> JointOpacity

-- | The position of a name part or underscore in a name.
data PositionInName

-- | The following underscore is at the beginning of the name:
--   <tt>_foo</tt>.
Beginning :: PositionInName

-- | The following underscore is in the middle of the name:
--   <tt>foo_bar</tt>.
Middle :: PositionInName

-- | The following underscore is at the end of the name: <tt>foo_</tt>.
End :: PositionInName

-- | Placeholders are used to represent the underscores in a section.
data MaybePlaceholder e
Placeholder :: !PositionInName -> MaybePlaceholder e

-- | The second argument is used only (but not always) for name parts other
--   than underscores.
NoPlaceholder :: !Maybe PositionInName -> e -> MaybePlaceholder e

-- | Precedence levels for operators.
type PrecedenceLevel = Double
data FixityLevel

-- | No fixity declared.
Unrelated :: FixityLevel

-- | Fixity level declared as the number.
Related :: !PrecedenceLevel -> FixityLevel

-- | The notation is handled as the fixity in the renamer. Hence, they are
--   grouped together in this type.
data Fixity'
Fixity' :: !Fixity -> Notation -> Range -> Fixity'
[theFixity] :: Fixity' -> !Fixity
[theNotation] :: Fixity' -> Notation

-- | Range of the name in the fixity declaration (used for correct
--   highlighting, see issue #2140).
[theNameRange] :: Fixity' -> Range
class LensFixity a
lensFixity :: LensFixity a => Lens' a Fixity
class LensFixity' a
lensFixity' :: LensFixity' a => Lens' a Fixity'

-- | The things you are allowed to say when you shuffle names between name
--   spaces (i.e. in <tt>import</tt>, <tt>namespace</tt>, or <tt>open</tt>
--   declarations).
data ImportDirective' n m
ImportDirective :: Range -> Using' n m -> HidingDirective' n m -> RenamingDirective' n m -> Maybe KwRange -> ImportDirective' n m
[importDirRange] :: ImportDirective' n m -> Range
[using] :: ImportDirective' n m -> Using' n m
[hiding] :: ImportDirective' n m -> HidingDirective' n m
[impRenaming] :: ImportDirective' n m -> RenamingDirective' n m

-- | Only for <tt>open</tt>. Exports the opened names from the current
--   module. Range of the <tt>public</tt> keyword.
[publicOpen] :: ImportDirective' n m -> Maybe KwRange

-- | The <tt>using</tt> clause of import directive.
data Using' n m

-- | No <tt>using</tt> clause given.
UseEverything :: Using' n m

-- | <tt>using</tt> the specified names.
Using :: [ImportedName' n m] -> Using' n m
type HidingDirective' n m = [ImportedName' n m]
type RenamingDirective' n m = [Renaming' n m]
data Renaming' n m
Renaming :: ImportedName' n m -> ImportedName' n m -> Maybe Fixity -> Range -> Renaming' n m

-- | Rename from this name.
[renFrom] :: Renaming' n m -> ImportedName' n m

-- | To this one. Must be same kind as <a>renFrom</a>.
[renTo] :: Renaming' n m -> ImportedName' n m

-- | New fixity of <a>renTo</a> (optional).
[renFixity] :: Renaming' n m -> Maybe Fixity

-- | The range of the "to" keyword. Retained for highlighting purposes.
[renToRange] :: Renaming' n m -> Range

-- | Positivity check? (Default = True).
data PositivityCheck
YesPositivityCheck :: PositivityCheck
NoPositivityCheck :: PositivityCheck

-- | Universe check? (Default is yes).
data UniverseCheck
YesUniverseCheck :: UniverseCheck
NoUniverseCheck :: UniverseCheck

-- | Coverage check? (Default is yes).
data CoverageCheck
YesCoverageCheck :: CoverageCheck
NoCoverageCheck :: CoverageCheck

-- | <tt>RewriteEqn' qn p e</tt> represents the <tt>rewrite</tt> and
--   irrefutable <tt>with</tt> clauses of the LHS. <tt>qn</tt> stands for
--   the QName of the auxiliary function generated to implement the feature
--   <tt>nm</tt> is the type of names for pattern variables <tt>p</tt> is
--   the type of patterns <tt>e</tt> is the type of expressions
data RewriteEqn' qn nm p e

-- | <pre>
--   rewrite e
--   </pre>
Rewrite :: List1 (qn, e) -> RewriteEqn' qn nm p e

-- | <pre>
--   with p &lt;- e in eq
--   </pre>
Invert :: qn -> List1 (Named nm (p, e)) -> RewriteEqn' qn nm p e

-- | <pre>
--   using p &lt;- e
--   </pre>
LeftLet :: List1 (p, e) -> RewriteEqn' qn nm p e
data ExpandedEllipsis
ExpandedEllipsis :: Range -> Int -> ExpandedEllipsis
[ellipsisRange] :: ExpandedEllipsis -> Range
[ellipsisWithArgs] :: ExpandedEllipsis -> Int
NoEllipsis :: ExpandedEllipsis

-- | Notation parts.
data NotationPart

-- | An identifier part. For instance, for <tt>_+_</tt> the only identifier
--   part is <tt>+</tt>.
IdPart :: RString -> NotationPart

-- | A hole: a place where argument expressions can be written. For
--   instance, for <tt>_+_</tt> the two underscores are holes, and for
--   <tt>syntax Σ A (λ x → B) = B , A , x</tt> the variables <tt>A</tt> and
--   <tt>B</tt> are holes. The number is the position of the hole, counting
--   from zero. For instance, the number for <tt>A</tt> is <tt>0</tt>, and
--   the number for <tt>B</tt> is <tt>1</tt>.
HolePart :: Range -> NamedArg (Ranged Int) -> NotationPart

-- | A bound variable.
--   
--   The first range is the range of the variable in the right-hand side of
--   the syntax declaration, and the second range is the range of the
--   variable in the left-hand side.
VarPart :: Range -> Ranged BoundVariablePosition -> NotationPart

-- | A wildcard (an underscore in binding position).
WildPart :: Ranged BoundVariablePosition -> NotationPart

-- | Positions of variables in syntax declarations.
data BoundVariablePosition
BoundVariablePosition :: !Int -> !Int -> BoundVariablePosition

-- | The position (in the left-hand side of the syntax declaration) of the
--   hole in which the variable is bound, counting from zero (and excluding
--   parts that are not holes). For instance, for <tt>syntax Σ A (λ x → B)
--   = B , A , x</tt> the number for <tt>x</tt> is <tt>1</tt>,
--   corresponding to <tt>B</tt> (<tt>0</tt> would correspond to
--   <tt>A</tt>).
[holeNumber] :: BoundVariablePosition -> !Int

-- | The position in the list of variables for this particular variable,
--   counting from zero, and including wildcards. For instance, for
--   <tt>syntax F (λ x _ y → A) = y ! A ! x</tt> the number for <tt>x</tt>
--   is <tt>0</tt>, the number for <tt>_</tt> is <tt>1</tt>, and the number
--   for <tt>y</tt> is <tt>2</tt>.
[varNumber] :: BoundVariablePosition -> !Int

-- | <a>Hidden</a> arguments are <tt>hidden</tt>.
hidden :: LensHiding a => a -> Bool
isInstance :: LensHiding a => a -> Bool
defaultFixity :: Fixity
defaultArgInfo :: ArgInfo

-- | <a>NotHidden</a> arguments are <tt>visible</tt>.
visible :: LensHiding a => a -> Bool
fromImportedName :: ImportedName' a a -> a

-- | Like <tt>partitionEithers</tt>.
partitionImportedNames :: [ImportedName' n m] -> ([n], [m])
defaultArg :: a -> Arg a

-- | Check for <a>Quantity0</a>.
hasQuantity0 :: LensQuantity a => a -> Bool
emptyRecordDirectives :: RecordDirectives' a
isIncoherent :: HasOverlapMode a => a -> Bool
isOverlappable :: HasOverlapMode a => a -> Bool
isOverlapping :: HasOverlapMode a => a -> Bool
hidingToString :: Hiding -> String

-- | Monoidal composition of <a>Hiding</a> information in some data.
mergeHiding :: LensHiding a => WithHiding a -> a

-- | <a>Instance</a> and <a>Hidden</a> arguments are <tt>notVisible</tt>.
notVisible :: LensHiding a => a -> Bool
hide :: LensHiding a => a -> a
hideOrKeepInstance :: LensHiding a => a -> a
makeInstance :: LensHiding a => a -> a
makeInstance' :: LensHiding a => Overlappable -> a -> a
isYesOverlap :: LensHiding a => a -> Bool

-- | Ignores <a>Overlappable</a>.
sameHiding :: (LensHiding a, LensHiding b) => a -> b -> Bool

-- | Multiplicative monoid (standard monoid).
composeModality :: Modality -> Modality -> Modality

-- | Identity under composition
unitModality :: Modality

-- | <tt>inverseComposeModality r x</tt> returns the least modality
--   <tt>y</tt> such that forall <tt>x</tt>, <tt>y</tt> we have <tt>x
--   `moreUsableModality` (r `composeModality` y)</tt> iff <tt>(r
--   `inverseComposeModality` x) `moreUsableModality` y</tt> (Galois
--   connection).
inverseComposeModality :: Modality -> Modality -> Modality

-- | <a>Modality</a> forms a pointwise additive monoid.
addModality :: Modality -> Modality -> Modality

-- | Identity under addition
zeroModality :: Modality

-- | <tt>m <a>moreUsableModality</a> m'</tt> means that an <tt>m</tt> can
--   be used where ever an <tt>m'</tt> is required.
moreUsableModality :: Modality -> Modality -> Bool
usableModality :: LensModality a => a -> Bool

-- | <tt>usableRelevance rel == False</tt> iff we cannot use a variable of
--   <tt>rel</tt>.
usableRelevance :: LensRelevance a => a -> Bool

-- | A thing of quantity 0 is unusable, all others are usable.
usableQuantity :: LensQuantity a => a -> Bool

-- | <tt>usableCohesion rel == False</tt> iff we cannot use a variable of
--   <tt>rel</tt>.
usableCohesion :: LensCohesion a => a -> Bool

-- | <a>Relevance</a> composition. <a>Irrelevant</a> is dominant,
--   <a>Relevant</a> is neutral. Composition coincides with <a>max</a>.
composeRelevance :: Relevance -> Relevance -> Relevance

-- | Composition of quantities (multiplication).
--   
--   <a>Quantity0</a> is dominant. <a>Quantity1</a> is neutral.
--   
--   Right-biased for origin.
composeQuantity :: Quantity -> Quantity -> Quantity

-- | <a>Cohesion</a> composition. <a>Squash</a> is dominant,
--   <a>Continuous</a> is neutral.
composeCohesion :: Cohesion -> Cohesion -> Cohesion

-- | Compose with modality flag from the left. This function is e.g. used
--   to update the modality information on pattern variables <tt>a</tt>
--   after a match against something of modality <tt>q</tt>.
applyModality :: LensModality a => Modality -> a -> a

-- | <tt>inverseComposeRelevance r x</tt> returns the most irrelevant
--   <tt>y</tt> such that forall <tt>x</tt>, <tt>y</tt> we have <tt>x
--   `moreRelevant` (r `composeRelevance` y)</tt> iff <tt>(r
--   `inverseComposeRelevance` x) `moreRelevant` y</tt> (Galois
--   connection).
inverseComposeRelevance :: Relevance -> Relevance -> Relevance

-- | <tt>inverseComposeQuantity r x</tt> returns the least quantity
--   <tt>y</tt> such that forall <tt>x</tt>, <tt>y</tt> we have <tt>x
--   `moreQuantity` (r `composeQuantity` y)</tt> iff <tt>(r
--   `inverseComposeQuantity` x) `moreQuantity` y</tt> (Galois connection).
inverseComposeQuantity :: Quantity -> Quantity -> Quantity

-- | <tt>inverseComposeCohesion r x</tt> returns the least <tt>y</tt> such
--   that forall <tt>x</tt>, <tt>y</tt> we have <tt>x `moreCohesion` (r
--   `composeCohesion` y)</tt> iff <tt>(r `inverseComposeCohesion` x)
--   `moreCohesion` y</tt> (Galois connection). The above law fails for
--   <tt>r = Squash</tt>.
inverseComposeCohesion :: Cohesion -> Cohesion -> Cohesion

-- | Left division by a <a>Modality</a>. Used e.g. to modify context when
--   going into a <tt>m</tt> argument.
--   
--   Note that this function does not change quantities.
inverseApplyModalityButNotQuantity :: LensModality a => Modality -> a -> a

-- | Combine inferred <a>Relevance</a>. The unit is <a>Irrelevant</a>.
addRelevance :: Relevance -> Relevance -> Relevance

-- | <a>Quantity</a> forms an additive monoid with zero Quantity0.
addQuantity :: Quantity -> Quantity -> Quantity

-- | Combine inferred <a>Cohesion</a>. The unit is <a>Squash</a>.
addCohesion :: Cohesion -> Cohesion -> Cohesion

-- | <a>Relevance</a> forms a monoid under addition, and even a semiring.
zeroRelevance :: Relevance

-- | Identity element under addition
zeroQuantity :: Quantity

-- | <a>Cohesion</a> forms a monoid under addition, and even a semiring.
zeroCohesion :: Cohesion

-- | Identity element under composition
unitRelevance :: Relevance

-- | Identity element under composition
unitQuantity :: Quantity

-- | Identity under composition
unitCohesion :: Cohesion

-- | Absorptive element under addition.
topModality :: Modality

-- | Absorptive element under addition.
topRelevance :: Relevance

-- | Absorptive element is ω.
topQuantity :: Quantity

-- | Absorptive element under addition.
topCohesion :: Cohesion

-- | The default Modality Beware that this is neither the additive unit nor
--   the unit under composition, because the default quantity is ω.
defaultModality :: Modality

-- | Default Relevance is the identity element under composition
defaultRelevance :: Relevance

-- | Absorptive element! This differs from Relevance and Cohesion whose
--   default is the multiplicative unit.
defaultQuantity :: Quantity

-- | Default Cohesion is the identity element under composition
defaultCohesion :: Cohesion

-- | Equality ignoring origin.
sameModality :: (LensModality a, LensModality b) => a -> b -> Bool

-- | Equality ignoring origin.
sameRelevance :: Relevance -> Relevance -> Bool

-- | Equality ignoring origin.
sameQuantity :: Quantity -> Quantity -> Bool

-- | Equality ignoring origin.
sameCohesion :: Cohesion -> Cohesion -> Bool
lModRelevance :: Lens' Modality Relevance
lModQuantity :: Lens' Modality Quantity
lModCohesion :: Lens' Modality Cohesion
getRelevanceMod :: LensModality a => LensGet a Relevance
setRelevanceMod :: LensModality a => LensSet a Relevance
mapRelevanceMod :: LensModality a => LensMap a Relevance
getQuantityMod :: LensModality a => LensGet a Quantity
setQuantityMod :: LensModality a => LensSet a Quantity
mapQuantityMod :: LensModality a => LensMap a Quantity
getCohesionMod :: LensModality a => LensGet a Cohesion
setCohesionMod :: LensModality a => LensSet a Cohesion
mapCohesionMod :: LensModality a => LensMap a Cohesion

-- | <tt>m <tt>moreUsableQuantity</tt> m'</tt> means that an <tt>m</tt> can
--   be used where ever an <tt>m'</tt> is required.
moreQuantity :: Quantity -> Quantity -> Bool

-- | Compose with quantity flag from the left. This function is e.g. used
--   to update the quantity information on pattern variables <tt>a</tt>
--   after a match against something of quantity <tt>q</tt>.
applyQuantity :: LensQuantity a => Quantity -> a -> a

-- | Left division by a <a>Quantity</a>. Used e.g. to modify context when
--   going into a <tt>q</tt> argument.
inverseApplyQuantity :: LensQuantity a => Quantity -> a -> a

-- | Check for <a>Quantity1</a>.
hasQuantity1 :: LensQuantity a => a -> Bool

-- | Check for <a>Quantityω</a>.
hasQuantityω :: LensQuantity a => a -> Bool

-- | Did the user supply a quantity annotation?
noUserQuantity :: LensQuantity a => a -> Bool
isQuantityω :: LensQuantity a => a -> Bool

-- | The default value of type <a>Erased</a>: not erased.
defaultErased :: Erased

-- | <a>Erased</a> can be embedded into <a>Quantity</a>.
asQuantity :: Erased -> Quantity

-- | <a>Quantity</a> can be projected onto <a>Erased</a>.
erasedFromQuantity :: Quantity -> Maybe Erased

-- | Equality ignoring origin.
sameErased :: Erased -> Erased -> Bool

-- | Is the value "erased"?
isErased :: Erased -> Bool

-- | Composition of values of type <a>Erased</a>.
--   
--   <a>Erased</a> is dominant. <a>NotErased</a> is neutral.
--   
--   Right-biased for the origin.
composeErased :: Erased -> Erased -> Erased
allRelevances :: [Relevance]
isRelevant :: LensRelevance a => a -> Bool
isIrrelevant :: LensRelevance a => a -> Bool
isNonStrict :: LensRelevance a => a -> Bool

-- | Information ordering. <tt>Relevant `moreRelevant` NonStrict
--   `moreRelevant` Irrelevant</tt>
moreRelevant :: Relevance -> Relevance -> Bool

-- | Compose with relevance flag from the left. This function is e.g. used
--   to update the relevance information on pattern variables <tt>a</tt>
--   after a match against something <tt>rel</tt>.
applyRelevance :: LensRelevance a => Relevance -> a -> a

-- | Left division by a <a>Relevance</a>. Used e.g. to modify context when
--   going into a <tt>rel</tt> argument.
inverseApplyRelevance :: LensRelevance a => Relevance -> a -> a

-- | Irrelevant function arguments may appear non-strictly in the codomain
--   type.
irrToNonStrict :: Relevance -> Relevance

-- | Applied when working on types (unless --experimental-irrelevance).
nonStrictToRel :: Relevance -> Relevance
nonStrictToIrr :: Relevance -> Relevance
defaultAnnotation :: Annotation
defaultLock :: Lock
allCohesions :: [Cohesion]
isContinuous :: LensCohesion a => a -> Bool

-- | Information ordering. <tt>Flat `moreCohesion` Continuous
--   `moreCohesion` Sharp `moreCohesion` Squash</tt>
moreCohesion :: Cohesion -> Cohesion -> Bool

-- | Compose with cohesion flag from the left. This function is e.g. used
--   to update the cohesion information on pattern variables <tt>a</tt>
--   after a match against something of cohesion <tt>rel</tt>.
applyCohesion :: LensCohesion a => Cohesion -> a -> a

-- | Left division by a <a>Cohesion</a>. Used e.g. to modify context when
--   going into a <tt>rel</tt> argument.
inverseApplyCohesion :: LensCohesion a => Cohesion -> a -> a
unknownFreeVariables :: FreeVariables
noFreeVariables :: FreeVariables
oneFreeVariable :: Int -> FreeVariables
freeVariablesFromList :: [Int] -> FreeVariables
hasNoFreeVariables :: LensFreeVariables a => a -> Bool
getHidingArgInfo :: LensArgInfo a => LensGet a Hiding
setHidingArgInfo :: LensArgInfo a => LensSet a Hiding
mapHidingArgInfo :: LensArgInfo a => LensMap a Hiding
getModalityArgInfo :: LensArgInfo a => LensGet a Modality
setModalityArgInfo :: LensArgInfo a => LensSet a Modality
mapModalityArgInfo :: LensArgInfo a => LensMap a Modality
getOriginArgInfo :: LensArgInfo a => LensGet a Origin
setOriginArgInfo :: LensArgInfo a => LensSet a Origin
mapOriginArgInfo :: LensArgInfo a => LensMap a Origin
getFreeVariablesArgInfo :: LensArgInfo a => LensGet a FreeVariables
setFreeVariablesArgInfo :: LensArgInfo a => LensSet a FreeVariables
mapFreeVariablesArgInfo :: LensArgInfo a => LensMap a FreeVariables
isInsertedHidden :: (LensHiding a, LensOrigin a) => a -> Bool

-- | <tt>xs `withArgsFrom` args</tt> translates <tt>xs</tt> into a list of
--   <a>Arg</a>s, using the elements in <tt>args</tt> to fill in the
--   non-<a>unArg</a> fields.
--   
--   Precondition: The two lists should have equal length.
withArgsFrom :: [a] -> [Arg b] -> [Arg a]
withNamedArgsFrom :: [a] -> [NamedArg b] -> [NamedArg a]

-- | Equality of argument names of things modulo <a>Range'</a> and
--   <a>Origin</a>.
sameName :: NamedName -> NamedName -> Bool
unnamed :: a -> Named name a
isUnnamed :: Named name a -> Maybe a
named :: name -> a -> Named name a
userNamed :: Ranged ArgName -> a -> Named_ a
getNameOf :: LensNamed a => a -> Maybe (NameOf a)
setNameOf :: LensNamed a => Maybe (NameOf a) -> a -> a
mapNameOf :: LensNamed a => (Maybe (NameOf a) -> Maybe (NameOf a)) -> a -> a
bareNameOf :: (LensNamed a, NameOf a ~ NamedName) => a -> Maybe ArgName
bareNameWithDefault :: (LensNamed a, NameOf a ~ NamedName) => ArgName -> a -> ArgName

-- | Equality of argument names of things modulo <a>Range'</a> and
--   <a>Origin</a>.
namedSame :: (LensNamed a, LensNamed b, NameOf a ~ NamedName, NameOf b ~ NamedName) => a -> b -> Bool

-- | Does an argument <tt>arg</tt> fit the shape <tt>dom</tt> of the next
--   expected argument?
--   
--   The hiding has to match, and if the argument has a name, it should
--   match the name of the domain.
--   
--   <a>Nothing</a> should be <a>__IMPOSSIBLE__</a>, so use as @<tt>
--   fromMaybe <b>IMPOSSIBLE</b> $ fittingNamedArg arg dom </tt>@
fittingNamedArg :: (LensNamed arg, NameOf arg ~ NamedName, LensHiding arg, LensNamed dom, NameOf dom ~ NamedName, LensHiding dom) => arg -> dom -> Maybe Bool

-- | Get the content of a <a>NamedArg</a>.
namedArg :: NamedArg a -> a
defaultNamedArg :: a -> NamedArg a
unnamedArg :: ArgInfo -> a -> NamedArg a

-- | The functor instance for <a>NamedArg</a> would be ambiguous, so we
--   give it another name here.
updateNamedArg :: (a -> b) -> NamedArg a -> NamedArg b
updateNamedArgA :: Applicative f => (a -> f b) -> NamedArg a -> f (NamedArg b)

-- | <pre>
--   setNamedArg a b = updateNamedArg (const b) a
--   </pre>
setNamedArg :: NamedArg a -> b -> NamedArg b
argNameToString :: ArgName -> String
stringToArgName :: String -> ArgName
appendArgNames :: ArgName -> ArgName -> ArgName

-- | Thing with no range info.
unranged :: a -> Ranged a
rawNameToString :: RawName -> String
stringToRawName :: String -> RawName

-- | Prefer user-written over system-inserted.
bestConInfo :: ConOrigin -> ConOrigin -> ConOrigin
privateAccessInserted :: Access

-- | An abbreviation: <tt>noPlaceholder = <a>NoPlaceholder</a>
--   <a>Nothing</a></tt>.
noPlaceholder :: e -> MaybePlaceholder e
noFixity :: Fixity
noFixity' :: Fixity'
noNotation :: Notation
_fixityAssoc :: Lens' Fixity Associativity
_fixityLevel :: Lens' Fixity FixityLevel

-- | Default is directive is <tt>private</tt> (use everything, but do not
--   export).
defaultImportDir :: ImportDirective' n m

-- | <tt>isDefaultImportDir</tt> implies <tt>null</tt>, but not the other
--   way round.
isDefaultImportDir :: ImportDirective' n m -> Bool
mapUsing :: ([ImportedName' n1 m1] -> [ImportedName' n2 m2]) -> Using' n1 m1 -> Using' n2 m2
setImportedName :: ImportedName' a a -> a -> ImportedName' a a
data Induction
Inductive :: Induction
CoInductive :: Induction
instance GHC.Show.Show Agda.Syntax.Common.IsMain
instance GHC.Classes.Eq Agda.Syntax.Common.IsMain
instance GHC.Generics.Generic Agda.Syntax.Common.FileType
instance GHC.Show.Show Agda.Syntax.Common.FileType
instance GHC.Classes.Ord Agda.Syntax.Common.FileType
instance GHC.Classes.Eq Agda.Syntax.Common.FileType
instance GHC.Generics.Generic Agda.Syntax.Common.Cubical
instance GHC.Show.Show Agda.Syntax.Common.Cubical
instance GHC.Classes.Eq Agda.Syntax.Common.Cubical
instance GHC.Generics.Generic Agda.Syntax.Common.Language
instance GHC.Show.Show Agda.Syntax.Common.Language
instance GHC.Classes.Eq Agda.Syntax.Common.Language
instance Data.Traversable.Traversable Agda.Syntax.Common.HasEta'
instance Data.Foldable.Foldable Agda.Syntax.Common.HasEta'
instance GHC.Base.Functor Agda.Syntax.Common.HasEta'
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.Syntax.Common.HasEta' a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Common.HasEta' a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Common.HasEta' a)
instance GHC.Enum.Bounded Agda.Syntax.Common.PatternOrCopattern
instance GHC.Enum.Enum Agda.Syntax.Common.PatternOrCopattern
instance GHC.Classes.Ord Agda.Syntax.Common.PatternOrCopattern
instance GHC.Classes.Eq Agda.Syntax.Common.PatternOrCopattern
instance GHC.Show.Show Agda.Syntax.Common.PatternOrCopattern
instance GHC.Classes.Ord Agda.Syntax.Common.Overlappable
instance GHC.Classes.Eq Agda.Syntax.Common.Overlappable
instance GHC.Show.Show Agda.Syntax.Common.Overlappable
instance GHC.Enum.Bounded Agda.Syntax.Common.OverlapMode
instance GHC.Enum.Enum Agda.Syntax.Common.OverlapMode
instance GHC.Classes.Ord Agda.Syntax.Common.OverlapMode
instance GHC.Classes.Eq Agda.Syntax.Common.OverlapMode
instance GHC.Show.Show Agda.Syntax.Common.OverlapMode
instance GHC.Classes.Ord Agda.Syntax.Common.Hiding
instance GHC.Classes.Eq Agda.Syntax.Common.Hiding
instance GHC.Show.Show Agda.Syntax.Common.Hiding
instance Data.Traversable.Traversable Agda.Syntax.Common.WithHiding
instance Data.Foldable.Foldable Agda.Syntax.Common.WithHiding
instance GHC.Base.Functor Agda.Syntax.Common.WithHiding
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Common.WithHiding a)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.Syntax.Common.WithHiding a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Common.WithHiding a)
instance Agda.Utils.PartialOrd.PartialOrd t => Agda.Utils.PartialOrd.PartialOrd (Agda.Syntax.Common.UnderAddition t)
instance GHC.Classes.Ord t => GHC.Classes.Ord (Agda.Syntax.Common.UnderAddition t)
instance GHC.Classes.Eq t => GHC.Classes.Eq (Agda.Syntax.Common.UnderAddition t)
instance GHC.Base.Functor Agda.Syntax.Common.UnderAddition
instance GHC.Show.Show t => GHC.Show.Show (Agda.Syntax.Common.UnderAddition t)
instance Agda.Utils.PartialOrd.PartialOrd t => Agda.Utils.PartialOrd.PartialOrd (Agda.Syntax.Common.UnderComposition t)
instance GHC.Classes.Ord t => GHC.Classes.Ord (Agda.Syntax.Common.UnderComposition t)
instance GHC.Classes.Eq t => GHC.Classes.Eq (Agda.Syntax.Common.UnderComposition t)
instance GHC.Base.Functor Agda.Syntax.Common.UnderComposition
instance GHC.Show.Show t => GHC.Show.Show (Agda.Syntax.Common.UnderComposition t)
instance GHC.Classes.Ord Agda.Syntax.Common.Q0Origin
instance GHC.Classes.Eq Agda.Syntax.Common.Q0Origin
instance GHC.Generics.Generic Agda.Syntax.Common.Q0Origin
instance GHC.Show.Show Agda.Syntax.Common.Q0Origin
instance GHC.Classes.Ord Agda.Syntax.Common.Q1Origin
instance GHC.Classes.Eq Agda.Syntax.Common.Q1Origin
instance GHC.Generics.Generic Agda.Syntax.Common.Q1Origin
instance GHC.Show.Show Agda.Syntax.Common.Q1Origin
instance GHC.Classes.Ord Agda.Syntax.Common.QωOrigin
instance GHC.Classes.Eq Agda.Syntax.Common.QωOrigin
instance GHC.Generics.Generic Agda.Syntax.Common.QωOrigin
instance GHC.Show.Show Agda.Syntax.Common.QωOrigin
instance GHC.Classes.Ord Agda.Syntax.Common.Quantity
instance GHC.Classes.Eq Agda.Syntax.Common.Quantity
instance GHC.Generics.Generic Agda.Syntax.Common.Quantity
instance GHC.Show.Show Agda.Syntax.Common.Quantity
instance GHC.Generics.Generic Agda.Syntax.Common.Erased
instance GHC.Classes.Ord Agda.Syntax.Common.Erased
instance GHC.Classes.Eq Agda.Syntax.Common.Erased
instance GHC.Show.Show Agda.Syntax.Common.Erased
instance GHC.Generics.Generic Agda.Syntax.Common.Relevance
instance GHC.Enum.Bounded Agda.Syntax.Common.Relevance
instance GHC.Enum.Enum Agda.Syntax.Common.Relevance
instance GHC.Classes.Eq Agda.Syntax.Common.Relevance
instance GHC.Show.Show Agda.Syntax.Common.Relevance
instance GHC.Classes.Ord Agda.Syntax.Common.LockOrigin
instance GHC.Enum.Bounded Agda.Syntax.Common.LockOrigin
instance GHC.Enum.Enum Agda.Syntax.Common.LockOrigin
instance GHC.Classes.Eq Agda.Syntax.Common.LockOrigin
instance GHC.Generics.Generic Agda.Syntax.Common.LockOrigin
instance GHC.Show.Show Agda.Syntax.Common.LockOrigin
instance GHC.Classes.Ord Agda.Syntax.Common.Lock
instance GHC.Classes.Eq Agda.Syntax.Common.Lock
instance GHC.Generics.Generic Agda.Syntax.Common.Lock
instance GHC.Show.Show Agda.Syntax.Common.Lock
instance GHC.Generics.Generic Agda.Syntax.Common.Annotation
instance GHC.Show.Show Agda.Syntax.Common.Annotation
instance GHC.Classes.Ord Agda.Syntax.Common.Annotation
instance GHC.Classes.Eq Agda.Syntax.Common.Annotation
instance GHC.Generics.Generic Agda.Syntax.Common.Cohesion
instance GHC.Enum.Bounded Agda.Syntax.Common.Cohesion
instance GHC.Enum.Enum Agda.Syntax.Common.Cohesion
instance GHC.Classes.Eq Agda.Syntax.Common.Cohesion
instance GHC.Show.Show Agda.Syntax.Common.Cohesion
instance GHC.Generics.Generic Agda.Syntax.Common.Modality
instance GHC.Show.Show Agda.Syntax.Common.Modality
instance GHC.Classes.Ord Agda.Syntax.Common.Modality
instance GHC.Classes.Eq Agda.Syntax.Common.Modality
instance GHC.Classes.Ord Agda.Syntax.Common.Origin
instance GHC.Classes.Eq Agda.Syntax.Common.Origin
instance GHC.Show.Show Agda.Syntax.Common.Origin
instance Data.Traversable.Traversable Agda.Syntax.Common.WithOrigin
instance Data.Foldable.Foldable Agda.Syntax.Common.WithOrigin
instance GHC.Base.Functor Agda.Syntax.Common.WithOrigin
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Common.WithOrigin a)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.Syntax.Common.WithOrigin a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Common.WithOrigin a)
instance GHC.Show.Show Agda.Syntax.Common.FreeVariables
instance GHC.Classes.Ord Agda.Syntax.Common.FreeVariables
instance GHC.Classes.Eq Agda.Syntax.Common.FreeVariables
instance GHC.Show.Show Agda.Syntax.Common.ArgInfo
instance GHC.Classes.Ord Agda.Syntax.Common.ArgInfo
instance GHC.Classes.Eq Agda.Syntax.Common.ArgInfo
instance Data.Traversable.Traversable Agda.Syntax.Common.Arg
instance Data.Foldable.Foldable Agda.Syntax.Common.Arg
instance GHC.Base.Functor Agda.Syntax.Common.Arg
instance GHC.Show.Show e => GHC.Show.Show (Agda.Syntax.Common.Arg e)
instance GHC.Classes.Ord e => GHC.Classes.Ord (Agda.Syntax.Common.Arg e)
instance GHC.Classes.Eq e => GHC.Classes.Eq (Agda.Syntax.Common.Arg e)
instance Data.Traversable.Traversable (Agda.Syntax.Common.Named name)
instance Data.Foldable.Foldable (Agda.Syntax.Common.Named name)
instance GHC.Base.Functor (Agda.Syntax.Common.Named name)
instance (GHC.Show.Show name, GHC.Show.Show a) => GHC.Show.Show (Agda.Syntax.Common.Named name a)
instance (GHC.Classes.Ord name, GHC.Classes.Ord a) => GHC.Classes.Ord (Agda.Syntax.Common.Named name a)
instance (GHC.Classes.Eq name, GHC.Classes.Eq a) => GHC.Classes.Eq (Agda.Syntax.Common.Named name a)
instance Data.Traversable.Traversable Agda.Syntax.Common.Ranged
instance Data.Foldable.Foldable Agda.Syntax.Common.Ranged
instance GHC.Base.Functor Agda.Syntax.Common.Ranged
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Common.Ranged a)
instance Data.Traversable.Traversable Agda.Syntax.Common.RecordDirectives'
instance Data.Foldable.Foldable Agda.Syntax.Common.RecordDirectives'
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Common.RecordDirectives' a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Common.RecordDirectives' a)
instance GHC.Base.Functor Agda.Syntax.Common.RecordDirectives'
instance GHC.Generics.Generic Agda.Syntax.Common.ConOrigin
instance GHC.Enum.Bounded Agda.Syntax.Common.ConOrigin
instance GHC.Enum.Enum Agda.Syntax.Common.ConOrigin
instance GHC.Classes.Ord Agda.Syntax.Common.ConOrigin
instance GHC.Classes.Eq Agda.Syntax.Common.ConOrigin
instance GHC.Show.Show Agda.Syntax.Common.ConOrigin
instance GHC.Generics.Generic Agda.Syntax.Common.ProjOrigin
instance GHC.Enum.Bounded Agda.Syntax.Common.ProjOrigin
instance GHC.Enum.Enum Agda.Syntax.Common.ProjOrigin
instance GHC.Classes.Ord Agda.Syntax.Common.ProjOrigin
instance GHC.Classes.Eq Agda.Syntax.Common.ProjOrigin
instance GHC.Show.Show Agda.Syntax.Common.ProjOrigin
instance GHC.Classes.Ord Agda.Syntax.Common.IsInfix
instance GHC.Classes.Eq Agda.Syntax.Common.IsInfix
instance GHC.Show.Show Agda.Syntax.Common.IsInfix
instance GHC.Classes.Ord Agda.Syntax.Common.Access
instance GHC.Classes.Eq Agda.Syntax.Common.Access
instance GHC.Show.Show Agda.Syntax.Common.Access
instance GHC.Generics.Generic Agda.Syntax.Common.IsAbstract
instance GHC.Classes.Ord Agda.Syntax.Common.IsAbstract
instance GHC.Classes.Eq Agda.Syntax.Common.IsAbstract
instance GHC.Show.Show Agda.Syntax.Common.IsAbstract
instance GHC.Classes.Ord Agda.Syntax.Common.IsInstance
instance GHC.Classes.Eq Agda.Syntax.Common.IsInstance
instance GHC.Show.Show Agda.Syntax.Common.IsInstance
instance GHC.Generics.Generic Agda.Syntax.Common.IsMacro
instance GHC.Classes.Ord Agda.Syntax.Common.IsMacro
instance GHC.Classes.Eq Agda.Syntax.Common.IsMacro
instance GHC.Show.Show Agda.Syntax.Common.IsMacro
instance GHC.Show.Show Agda.Syntax.Common.NameId
instance GHC.Generics.Generic Agda.Syntax.Common.NameId
instance GHC.Classes.Ord Agda.Syntax.Common.NameId
instance GHC.Classes.Eq Agda.Syntax.Common.NameId
instance GHC.Generics.Generic Agda.Syntax.Common.MetaId
instance GHC.Classes.Ord Agda.Syntax.Common.MetaId
instance GHC.Classes.Eq Agda.Syntax.Common.MetaId
instance Control.DeepSeq.NFData Agda.Syntax.Common.ProblemId
instance GHC.Num.Num Agda.Syntax.Common.ProblemId
instance GHC.Real.Integral Agda.Syntax.Common.ProblemId
instance GHC.Real.Real Agda.Syntax.Common.ProblemId
instance GHC.Enum.Enum Agda.Syntax.Common.ProblemId
instance GHC.Classes.Ord Agda.Syntax.Common.ProblemId
instance GHC.Classes.Eq Agda.Syntax.Common.ProblemId
instance GHC.Show.Show Agda.Syntax.Common.OpaqueId
instance GHC.Generics.Generic Agda.Syntax.Common.OpaqueId
instance GHC.Classes.Ord Agda.Syntax.Common.OpaqueId
instance GHC.Classes.Eq Agda.Syntax.Common.OpaqueId
instance GHC.Generics.Generic Agda.Syntax.Common.IsOpaque
instance GHC.Classes.Ord Agda.Syntax.Common.IsOpaque
instance GHC.Classes.Eq Agda.Syntax.Common.IsOpaque
instance GHC.Show.Show Agda.Syntax.Common.IsOpaque
instance GHC.Classes.Ord Agda.Syntax.Common.PositionInName
instance GHC.Classes.Eq Agda.Syntax.Common.PositionInName
instance GHC.Show.Show Agda.Syntax.Common.PositionInName
instance GHC.Show.Show e => GHC.Show.Show (Agda.Syntax.Common.MaybePlaceholder e)
instance Data.Traversable.Traversable Agda.Syntax.Common.MaybePlaceholder
instance Data.Foldable.Foldable Agda.Syntax.Common.MaybePlaceholder
instance GHC.Base.Functor Agda.Syntax.Common.MaybePlaceholder
instance GHC.Classes.Ord e => GHC.Classes.Ord (Agda.Syntax.Common.MaybePlaceholder e)
instance GHC.Classes.Eq e => GHC.Classes.Eq (Agda.Syntax.Common.MaybePlaceholder e)
instance Control.DeepSeq.NFData Agda.Syntax.Common.InteractionId
instance GHC.Enum.Enum Agda.Syntax.Common.InteractionId
instance GHC.Real.Real Agda.Syntax.Common.InteractionId
instance GHC.Real.Integral Agda.Syntax.Common.InteractionId
instance GHC.Num.Num Agda.Syntax.Common.InteractionId
instance GHC.Show.Show Agda.Syntax.Common.InteractionId
instance GHC.Classes.Ord Agda.Syntax.Common.InteractionId
instance GHC.Classes.Eq Agda.Syntax.Common.InteractionId
instance GHC.Show.Show Agda.Syntax.Common.FixityLevel
instance GHC.Classes.Ord Agda.Syntax.Common.FixityLevel
instance GHC.Classes.Eq Agda.Syntax.Common.FixityLevel
instance GHC.Show.Show Agda.Syntax.Common.Associativity
instance GHC.Classes.Ord Agda.Syntax.Common.Associativity
instance GHC.Classes.Eq Agda.Syntax.Common.Associativity
instance GHC.Show.Show Agda.Syntax.Common.Fixity
instance (GHC.Show.Show m, GHC.Show.Show n) => GHC.Show.Show (Agda.Syntax.Common.ImportedName' n m)
instance (GHC.Classes.Ord m, GHC.Classes.Ord n) => GHC.Classes.Ord (Agda.Syntax.Common.ImportedName' n m)
instance (GHC.Classes.Eq m, GHC.Classes.Eq n) => GHC.Classes.Eq (Agda.Syntax.Common.ImportedName' n m)
instance (GHC.Classes.Eq m, GHC.Classes.Eq n) => GHC.Classes.Eq (Agda.Syntax.Common.Using' n m)
instance (GHC.Classes.Eq m, GHC.Classes.Eq n) => GHC.Classes.Eq (Agda.Syntax.Common.Renaming' n m)
instance (GHC.Classes.Eq m, GHC.Classes.Eq n) => GHC.Classes.Eq (Agda.Syntax.Common.ImportDirective' n m)
instance GHC.Base.Functor Agda.Syntax.Common.TerminationCheck
instance GHC.Classes.Eq m => GHC.Classes.Eq (Agda.Syntax.Common.TerminationCheck m)
instance GHC.Show.Show m => GHC.Show.Show (Agda.Syntax.Common.TerminationCheck m)
instance GHC.Generics.Generic Agda.Syntax.Common.PositivityCheck
instance GHC.Enum.Enum Agda.Syntax.Common.PositivityCheck
instance GHC.Enum.Bounded Agda.Syntax.Common.PositivityCheck
instance GHC.Show.Show Agda.Syntax.Common.PositivityCheck
instance GHC.Classes.Ord Agda.Syntax.Common.PositivityCheck
instance GHC.Classes.Eq Agda.Syntax.Common.PositivityCheck
instance GHC.Generics.Generic Agda.Syntax.Common.UniverseCheck
instance GHC.Enum.Enum Agda.Syntax.Common.UniverseCheck
instance GHC.Enum.Bounded Agda.Syntax.Common.UniverseCheck
instance GHC.Show.Show Agda.Syntax.Common.UniverseCheck
instance GHC.Classes.Ord Agda.Syntax.Common.UniverseCheck
instance GHC.Classes.Eq Agda.Syntax.Common.UniverseCheck
instance GHC.Generics.Generic Agda.Syntax.Common.CoverageCheck
instance GHC.Enum.Enum Agda.Syntax.Common.CoverageCheck
instance GHC.Enum.Bounded Agda.Syntax.Common.CoverageCheck
instance GHC.Show.Show Agda.Syntax.Common.CoverageCheck
instance GHC.Classes.Ord Agda.Syntax.Common.CoverageCheck
instance GHC.Classes.Eq Agda.Syntax.Common.CoverageCheck
instance Data.Traversable.Traversable (Agda.Syntax.Common.RewriteEqn' qn nm p)
instance Data.Foldable.Foldable (Agda.Syntax.Common.RewriteEqn' qn nm p)
instance GHC.Base.Functor (Agda.Syntax.Common.RewriteEqn' qn nm p)
instance (GHC.Show.Show e, GHC.Show.Show qn, GHC.Show.Show nm, GHC.Show.Show p) => GHC.Show.Show (Agda.Syntax.Common.RewriteEqn' qn nm p e)
instance (GHC.Classes.Eq e, GHC.Classes.Eq qn, GHC.Classes.Eq nm, GHC.Classes.Eq p) => GHC.Classes.Eq (Agda.Syntax.Common.RewriteEqn' qn nm p e)
instance GHC.Classes.Eq Agda.Syntax.Common.ExpandedEllipsis
instance GHC.Show.Show Agda.Syntax.Common.ExpandedEllipsis
instance GHC.Show.Show Agda.Syntax.Common.BoundVariablePosition
instance GHC.Classes.Ord Agda.Syntax.Common.BoundVariablePosition
instance GHC.Classes.Eq Agda.Syntax.Common.BoundVariablePosition
instance GHC.Show.Show Agda.Syntax.Common.NotationPart
instance GHC.Show.Show Agda.Syntax.Common.Fixity'
instance Agda.Syntax.Common.LensFixity' Agda.Syntax.Common.Fixity'
instance GHC.Classes.Eq Agda.Syntax.Common.Fixity'
instance Agda.Utils.Null.Null Agda.Syntax.Common.Fixity'
instance Control.DeepSeq.NFData Agda.Syntax.Common.Fixity'
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.Fixity'
instance Agda.Syntax.Common.LensFixity Agda.Syntax.Common.Fixity'
instance GHC.Classes.Eq Agda.Syntax.Common.NotationPart
instance GHC.Classes.Ord Agda.Syntax.Common.NotationPart
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.NotationPart
instance Agda.Syntax.Position.SetRange Agda.Syntax.Common.NotationPart
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.NotationPart
instance Control.DeepSeq.NFData Agda.Syntax.Common.NotationPart
instance Control.DeepSeq.NFData Agda.Syntax.Common.BoundVariablePosition
instance Agda.Utils.Null.Null Agda.Syntax.Common.ExpandedEllipsis
instance GHC.Base.Semigroup Agda.Syntax.Common.ExpandedEllipsis
instance GHC.Base.Monoid Agda.Syntax.Common.ExpandedEllipsis
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.ExpandedEllipsis
instance Control.DeepSeq.NFData Agda.Syntax.Common.ExpandedEllipsis
instance (Control.DeepSeq.NFData qn, Control.DeepSeq.NFData nm, Control.DeepSeq.NFData p, Control.DeepSeq.NFData e) => Control.DeepSeq.NFData (Agda.Syntax.Common.RewriteEqn' qn nm p e)
instance (Agda.Syntax.Common.Pretty.Pretty nm, Agda.Syntax.Common.Pretty.Pretty p, Agda.Syntax.Common.Pretty.Pretty e) => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Common.RewriteEqn' qn nm p e)
instance (Agda.Syntax.Position.HasRange qn, Agda.Syntax.Position.HasRange nm, Agda.Syntax.Position.HasRange p, Agda.Syntax.Position.HasRange e) => Agda.Syntax.Position.HasRange (Agda.Syntax.Common.RewriteEqn' qn nm p e)
instance (Agda.Syntax.Position.KillRange qn, Agda.Syntax.Position.KillRange nm, Agda.Syntax.Position.KillRange e, Agda.Syntax.Position.KillRange p) => Agda.Syntax.Position.KillRange (Agda.Syntax.Common.RewriteEqn' qn nm p e)
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.CoverageCheck
instance GHC.Base.Semigroup Agda.Syntax.Common.CoverageCheck
instance GHC.Base.Monoid Agda.Syntax.Common.CoverageCheck
instance Control.DeepSeq.NFData Agda.Syntax.Common.CoverageCheck
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.UniverseCheck
instance Control.DeepSeq.NFData Agda.Syntax.Common.UniverseCheck
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.PositivityCheck
instance GHC.Base.Semigroup Agda.Syntax.Common.PositivityCheck
instance GHC.Base.Monoid Agda.Syntax.Common.PositivityCheck
instance Control.DeepSeq.NFData Agda.Syntax.Common.PositivityCheck
instance Agda.Syntax.Position.KillRange m => Agda.Syntax.Position.KillRange (Agda.Syntax.Common.TerminationCheck m)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Common.TerminationCheck a)
instance Agda.Utils.Null.Null (Agda.Syntax.Common.ImportDirective' n m)
instance (Agda.Syntax.Position.HasRange n, Agda.Syntax.Position.HasRange m) => GHC.Base.Semigroup (Agda.Syntax.Common.ImportDirective' n m)
instance (Agda.Syntax.Position.HasRange n, Agda.Syntax.Position.HasRange m) => GHC.Base.Monoid (Agda.Syntax.Common.ImportDirective' n m)
instance (Agda.Syntax.Position.HasRange a, Agda.Syntax.Position.HasRange b) => Agda.Syntax.Position.HasRange (Agda.Syntax.Common.ImportDirective' a b)
instance (Agda.Syntax.Position.KillRange a, Agda.Syntax.Position.KillRange b) => Agda.Syntax.Position.KillRange (Agda.Syntax.Common.ImportDirective' a b)
instance (Control.DeepSeq.NFData a, Control.DeepSeq.NFData b) => Control.DeepSeq.NFData (Agda.Syntax.Common.ImportDirective' a b)
instance (Agda.Syntax.Position.HasRange a, Agda.Syntax.Position.HasRange b) => Agda.Syntax.Position.HasRange (Agda.Syntax.Common.Renaming' a b)
instance (Agda.Syntax.Position.KillRange a, Agda.Syntax.Position.KillRange b) => Agda.Syntax.Position.KillRange (Agda.Syntax.Common.Renaming' a b)
instance (Control.DeepSeq.NFData a, Control.DeepSeq.NFData b) => Control.DeepSeq.NFData (Agda.Syntax.Common.Renaming' a b)
instance GHC.Base.Semigroup (Agda.Syntax.Common.Using' n m)
instance GHC.Base.Monoid (Agda.Syntax.Common.Using' n m)
instance Agda.Utils.Null.Null (Agda.Syntax.Common.Using' n m)
instance (Agda.Syntax.Position.HasRange a, Agda.Syntax.Position.HasRange b) => Agda.Syntax.Position.HasRange (Agda.Syntax.Common.Using' a b)
instance (Agda.Syntax.Position.KillRange a, Agda.Syntax.Position.KillRange b) => Agda.Syntax.Position.KillRange (Agda.Syntax.Common.Using' a b)
instance (Control.DeepSeq.NFData a, Control.DeepSeq.NFData b) => Control.DeepSeq.NFData (Agda.Syntax.Common.Using' a b)
instance (Agda.Syntax.Position.HasRange a, Agda.Syntax.Position.HasRange b) => Agda.Syntax.Position.HasRange (Agda.Syntax.Common.ImportedName' a b)
instance (Agda.Syntax.Position.KillRange a, Agda.Syntax.Position.KillRange b) => Agda.Syntax.Position.KillRange (Agda.Syntax.Common.ImportedName' a b)
instance (Control.DeepSeq.NFData a, Control.DeepSeq.NFData b) => Control.DeepSeq.NFData (Agda.Syntax.Common.ImportedName' a b)
instance Agda.Syntax.Common.LensFixity Agda.Syntax.Common.Fixity
instance GHC.Classes.Eq Agda.Syntax.Common.Fixity
instance GHC.Classes.Ord Agda.Syntax.Common.Fixity
instance Agda.Utils.Null.Null Agda.Syntax.Common.Fixity
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.Fixity
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.Fixity
instance Control.DeepSeq.NFData Agda.Syntax.Common.Fixity
instance Agda.Utils.Null.Null Agda.Syntax.Common.FixityLevel
instance Control.DeepSeq.NFData Agda.Syntax.Common.FixityLevel
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.InteractionId
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.InteractionId
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange (Agda.Syntax.Common.MaybePlaceholder a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Syntax.Common.MaybePlaceholder a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Common.MaybePlaceholder a)
instance Agda.Syntax.Common.LensIsOpaque Agda.Syntax.Common.IsOpaque
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.IsOpaque
instance Control.DeepSeq.NFData Agda.Syntax.Common.IsOpaque
instance Agda.Syntax.Common.AllAreOpaque Agda.Syntax.Common.IsOpaque
instance Agda.Syntax.Common.AllAreOpaque a => Agda.Syntax.Common.AllAreOpaque [a]
instance Agda.Syntax.Common.AllAreOpaque a => Agda.Syntax.Common.AllAreOpaque (GHC.Maybe.Maybe a)
instance GHC.Base.Semigroup Agda.Syntax.Common.JointOpacity
instance GHC.Base.Monoid Agda.Syntax.Common.JointOpacity
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.OpaqueId
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.OpaqueId
instance GHC.Enum.Enum Agda.Syntax.Common.OpaqueId
instance Control.DeepSeq.NFData Agda.Syntax.Common.OpaqueId
instance Data.Hashable.Class.Hashable Agda.Syntax.Common.OpaqueId
instance GHC.Show.Show Agda.Syntax.Common.ProblemId
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.ProblemId
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.MetaId
instance GHC.Enum.Enum Agda.Syntax.Common.MetaId
instance GHC.Show.Show Agda.Syntax.Common.MetaId
instance Control.DeepSeq.NFData Agda.Syntax.Common.MetaId
instance Data.Hashable.Class.Hashable Agda.Syntax.Common.MetaId
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.NameId
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.NameId
instance GHC.Enum.Enum Agda.Syntax.Common.NameId
instance Control.DeepSeq.NFData Agda.Syntax.Common.NameId
instance Data.Hashable.Class.Hashable Agda.Syntax.Common.NameId
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.IsMacro
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.IsMacro
instance Control.DeepSeq.NFData Agda.Syntax.Common.IsMacro
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.IsInstance
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.IsInstance
instance Control.DeepSeq.NFData Agda.Syntax.Common.IsInstance
instance Agda.Syntax.Common.AnyIsAbstract Agda.Syntax.Common.IsAbstract
instance Agda.Syntax.Common.AnyIsAbstract a => Agda.Syntax.Common.AnyIsAbstract [a]
instance Agda.Syntax.Common.AnyIsAbstract a => Agda.Syntax.Common.AnyIsAbstract (GHC.Maybe.Maybe a)
instance Agda.Syntax.Common.LensIsAbstract Agda.Syntax.Common.IsAbstract
instance GHC.Base.Semigroup Agda.Syntax.Common.IsAbstract
instance GHC.Base.Monoid Agda.Syntax.Common.IsAbstract
instance Agda.Utils.Boolean.Boolean Agda.Syntax.Common.IsAbstract
instance Agda.Utils.Boolean.IsBool Agda.Syntax.Common.IsAbstract
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.IsAbstract
instance Control.DeepSeq.NFData Agda.Syntax.Common.IsAbstract
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.Access
instance Control.DeepSeq.NFData Agda.Syntax.Common.Access
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.Access
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.Access
instance Control.DeepSeq.NFData Agda.Syntax.Common.ProjOrigin
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.ProjOrigin
instance Control.DeepSeq.NFData Agda.Syntax.Common.ConOrigin
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.ConOrigin
instance Agda.Utils.Null.Null (Agda.Syntax.Common.RecordDirectives' a)
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange (Agda.Syntax.Common.RecordDirectives' a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Syntax.Common.RecordDirectives' a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Common.RecordDirectives' a)
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Common.Ranged a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Common.Ranged a)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.Syntax.Common.Ranged a)
instance Agda.Syntax.Position.HasRange (Agda.Syntax.Common.Ranged a)
instance Agda.Syntax.Position.KillRange (Agda.Syntax.Common.Ranged a)
instance Agda.Utils.Functor.Decoration Agda.Syntax.Common.Ranged
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Common.Ranged a)
instance Agda.Syntax.Common.LensNamed a => Agda.Syntax.Common.LensNamed (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Common.LensNamed (GHC.Maybe.Maybe a)
instance Agda.Syntax.Common.LensNamed (Agda.Syntax.Common.Named name a)
instance Agda.Syntax.Common.LensHiding a => Agda.Syntax.Common.LensHiding (Agda.Syntax.Common.Named nm a)
instance Agda.Utils.Functor.Decoration (Agda.Syntax.Common.Named name)
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange (Agda.Syntax.Common.Named name a)
instance Agda.Syntax.Position.SetRange a => Agda.Syntax.Position.SetRange (Agda.Syntax.Common.Named name a)
instance (Agda.Syntax.Position.KillRange name, Agda.Syntax.Position.KillRange a) => Agda.Syntax.Position.KillRange (Agda.Syntax.Common.Named name a)
instance (Control.DeepSeq.NFData name, Control.DeepSeq.NFData a) => Control.DeepSeq.NFData (Agda.Syntax.Common.Named name a)
instance Agda.Syntax.Common.Underscore GHC.Base.String
instance Agda.Syntax.Common.Underscore Data.ByteString.Internal.Type.ByteString
instance Agda.Syntax.Common.Underscore Agda.Syntax.Common.Pretty.Doc
instance Agda.Syntax.Common.LensAnnotation (Agda.Syntax.Common.Arg t)
instance Agda.Syntax.Common.LensLock (Agda.Syntax.Common.Arg t)
instance Agda.Utils.Functor.Decoration Agda.Syntax.Common.Arg
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Position.SetRange a => Agda.Syntax.Position.SetRange (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Syntax.Common.Arg a)
instance Control.DeepSeq.NFData e => Control.DeepSeq.NFData (Agda.Syntax.Common.Arg e)
instance Agda.Syntax.Common.LensArgInfo (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Common.LensHiding (Agda.Syntax.Common.Arg e)
instance Agda.Syntax.Common.LensModality (Agda.Syntax.Common.Arg e)
instance Agda.Syntax.Common.LensOrigin (Agda.Syntax.Common.Arg e)
instance Agda.Syntax.Common.LensFreeVariables (Agda.Syntax.Common.Arg e)
instance Agda.Syntax.Common.LensRelevance (Agda.Syntax.Common.Arg e)
instance Agda.Syntax.Common.LensQuantity (Agda.Syntax.Common.Arg e)
instance Agda.Syntax.Common.LensCohesion (Agda.Syntax.Common.Arg e)
instance Agda.Syntax.Common.LensHiding Agda.Syntax.Common.Hiding
instance Agda.Syntax.Common.LensHiding (Agda.Syntax.Common.WithHiding a)
instance Agda.Syntax.Common.LensHiding Agda.Syntax.Common.ArgInfo
instance Agda.Syntax.Common.LensQuantity Agda.Syntax.Common.Modality
instance Agda.Syntax.Common.LensQuantity Agda.Syntax.Common.Quantity
instance Agda.Syntax.Common.LensQuantity Agda.Syntax.Common.ArgInfo
instance Agda.Syntax.Common.LensRelevance Agda.Syntax.Common.Modality
instance Agda.Syntax.Common.LensRelevance Agda.Syntax.Common.Relevance
instance Agda.Syntax.Common.LensRelevance Agda.Syntax.Common.ArgInfo
instance Agda.Syntax.Common.LensCohesion Agda.Syntax.Common.Modality
instance Agda.Syntax.Common.LensCohesion Agda.Syntax.Common.Cohesion
instance Agda.Syntax.Common.LensCohesion Agda.Syntax.Common.ArgInfo
instance Agda.Syntax.Common.LensModality Agda.Syntax.Common.Modality
instance Agda.Syntax.Common.LensModality Agda.Syntax.Common.ArgInfo
instance Agda.Syntax.Common.LensAnnotation Agda.Syntax.Common.Annotation
instance Agda.Syntax.Common.LensAnnotation Agda.Syntax.Common.ArgInfo
instance Agda.Syntax.Common.LensOrigin Agda.Syntax.Common.Origin
instance Agda.Syntax.Common.LensOrigin (Agda.Syntax.Common.WithOrigin a)
instance Agda.Syntax.Common.LensOrigin Agda.Syntax.Common.ArgInfo
instance Agda.Syntax.Common.LensFreeVariables Agda.Syntax.Common.FreeVariables
instance Agda.Syntax.Common.LensFreeVariables Agda.Syntax.Common.ArgInfo
instance Agda.Syntax.Common.LensArgInfo Agda.Syntax.Common.ArgInfo
instance Agda.Syntax.Common.LensLock Agda.Syntax.Common.ArgInfo
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.ArgInfo
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.ArgInfo
instance Control.DeepSeq.NFData Agda.Syntax.Common.ArgInfo
instance GHC.Base.Semigroup Agda.Syntax.Common.FreeVariables
instance GHC.Base.Monoid Agda.Syntax.Common.FreeVariables
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.FreeVariables
instance Control.DeepSeq.NFData Agda.Syntax.Common.FreeVariables
instance Agda.Utils.Functor.Decoration Agda.Syntax.Common.WithOrigin
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Common.WithOrigin a)
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange (Agda.Syntax.Common.WithOrigin a)
instance Agda.Syntax.Position.SetRange a => Agda.Syntax.Position.SetRange (Agda.Syntax.Common.WithOrigin a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Syntax.Common.WithOrigin a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Common.WithOrigin a)
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.Origin
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.Origin
instance Control.DeepSeq.NFData Agda.Syntax.Common.Origin
instance Agda.Utils.PartialOrd.PartialOrd Agda.Syntax.Common.Modality
instance GHC.Base.Semigroup (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Modality)
instance GHC.Base.Monoid (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Modality)
instance Agda.Utils.POMonoid.POSemigroup (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Modality)
instance Agda.Utils.POMonoid.POMonoid (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Modality)
instance Agda.Utils.POMonoid.LeftClosedPOMonoid (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Modality)
instance GHC.Base.Semigroup (Agda.Syntax.Common.UnderAddition Agda.Syntax.Common.Modality)
instance GHC.Base.Monoid (Agda.Syntax.Common.UnderAddition Agda.Syntax.Common.Modality)
instance Agda.Utils.POMonoid.POSemigroup (Agda.Syntax.Common.UnderAddition Agda.Syntax.Common.Modality)
instance Agda.Utils.POMonoid.POMonoid (Agda.Syntax.Common.UnderAddition Agda.Syntax.Common.Modality)
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.Modality
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.Modality
instance Control.DeepSeq.NFData Agda.Syntax.Common.Modality
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.Cohesion
instance Agda.Syntax.Position.SetRange Agda.Syntax.Common.Cohesion
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.Cohesion
instance Control.DeepSeq.NFData Agda.Syntax.Common.Cohesion
instance GHC.Classes.Ord Agda.Syntax.Common.Cohesion
instance Agda.Utils.PartialOrd.PartialOrd Agda.Syntax.Common.Cohesion
instance GHC.Base.Semigroup (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Cohesion)
instance GHC.Base.Monoid (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Cohesion)
instance Agda.Utils.POMonoid.POSemigroup (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Cohesion)
instance Agda.Utils.POMonoid.POMonoid (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Cohesion)
instance Agda.Utils.POMonoid.LeftClosedPOMonoid (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Cohesion)
instance GHC.Base.Semigroup (Agda.Syntax.Common.UnderAddition Agda.Syntax.Common.Cohesion)
instance GHC.Base.Monoid (Agda.Syntax.Common.UnderAddition Agda.Syntax.Common.Cohesion)
instance Agda.Utils.POMonoid.POSemigroup (Agda.Syntax.Common.UnderAddition Agda.Syntax.Common.Cohesion)
instance Agda.Utils.POMonoid.POMonoid (Agda.Syntax.Common.UnderAddition Agda.Syntax.Common.Cohesion)
instance Agda.Syntax.Common.LensLock Agda.Syntax.Common.Lock
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.Annotation
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.Annotation
instance Control.DeepSeq.NFData Agda.Syntax.Common.Annotation
instance Control.DeepSeq.NFData Agda.Syntax.Common.Lock
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.Relevance
instance Agda.Syntax.Position.SetRange Agda.Syntax.Common.Relevance
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.Relevance
instance Control.DeepSeq.NFData Agda.Syntax.Common.Relevance
instance GHC.Classes.Ord Agda.Syntax.Common.Relevance
instance Agda.Utils.PartialOrd.PartialOrd Agda.Syntax.Common.Relevance
instance GHC.Base.Semigroup (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Relevance)
instance GHC.Base.Monoid (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Relevance)
instance Agda.Utils.POMonoid.POSemigroup (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Relevance)
instance Agda.Utils.POMonoid.POMonoid (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Relevance)
instance Agda.Utils.POMonoid.LeftClosedPOMonoid (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Relevance)
instance GHC.Base.Semigroup (Agda.Syntax.Common.UnderAddition Agda.Syntax.Common.Relevance)
instance GHC.Base.Monoid (Agda.Syntax.Common.UnderAddition Agda.Syntax.Common.Relevance)
instance Agda.Utils.POMonoid.POSemigroup (Agda.Syntax.Common.UnderAddition Agda.Syntax.Common.Relevance)
instance Agda.Utils.POMonoid.POMonoid (Agda.Syntax.Common.UnderAddition Agda.Syntax.Common.Relevance)
instance Control.DeepSeq.NFData Agda.Syntax.Common.Erased
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.Erased
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.Erased
instance GHC.Base.Semigroup (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Erased)
instance GHC.Base.Semigroup (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Quantity)
instance GHC.Base.Monoid (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Quantity)
instance Agda.Utils.POMonoid.POSemigroup (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Quantity)
instance Agda.Utils.POMonoid.POMonoid (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Quantity)
instance Agda.Utils.POMonoid.LeftClosedPOMonoid (Agda.Syntax.Common.UnderComposition Agda.Syntax.Common.Quantity)
instance GHC.Base.Semigroup (Agda.Syntax.Common.UnderAddition Agda.Syntax.Common.Quantity)
instance GHC.Base.Monoid (Agda.Syntax.Common.UnderAddition Agda.Syntax.Common.Quantity)
instance Agda.Utils.POMonoid.POSemigroup (Agda.Syntax.Common.UnderAddition Agda.Syntax.Common.Quantity)
instance Agda.Utils.POMonoid.POMonoid (Agda.Syntax.Common.UnderAddition Agda.Syntax.Common.Quantity)
instance Agda.Utils.PartialOrd.PartialOrd Agda.Syntax.Common.Quantity
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.Quantity
instance Agda.Syntax.Position.SetRange Agda.Syntax.Common.Quantity
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.Quantity
instance Control.DeepSeq.NFData Agda.Syntax.Common.Quantity
instance GHC.Base.Semigroup Agda.Syntax.Common.QωOrigin
instance GHC.Base.Monoid Agda.Syntax.Common.QωOrigin
instance Agda.Utils.Null.Null Agda.Syntax.Common.QωOrigin
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.QωOrigin
instance Agda.Syntax.Position.SetRange Agda.Syntax.Common.QωOrigin
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.QωOrigin
instance Control.DeepSeq.NFData Agda.Syntax.Common.QωOrigin
instance GHC.Base.Semigroup Agda.Syntax.Common.Q1Origin
instance GHC.Base.Monoid Agda.Syntax.Common.Q1Origin
instance Agda.Utils.Null.Null Agda.Syntax.Common.Q1Origin
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.Q1Origin
instance Agda.Syntax.Position.SetRange Agda.Syntax.Common.Q1Origin
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.Q1Origin
instance Control.DeepSeq.NFData Agda.Syntax.Common.Q1Origin
instance GHC.Base.Semigroup Agda.Syntax.Common.Q0Origin
instance GHC.Base.Monoid Agda.Syntax.Common.Q0Origin
instance Agda.Utils.Null.Null Agda.Syntax.Common.Q0Origin
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.Q0Origin
instance Agda.Syntax.Position.SetRange Agda.Syntax.Common.Q0Origin
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.Q0Origin
instance Control.DeepSeq.NFData Agda.Syntax.Common.Q0Origin
instance GHC.Base.Applicative Agda.Syntax.Common.UnderComposition
instance GHC.Base.Applicative Agda.Syntax.Common.UnderAddition
instance Agda.Utils.Functor.Decoration Agda.Syntax.Common.WithHiding
instance GHC.Base.Applicative Agda.Syntax.Common.WithHiding
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange (Agda.Syntax.Common.WithHiding a)
instance Agda.Syntax.Position.SetRange a => Agda.Syntax.Position.SetRange (Agda.Syntax.Common.WithHiding a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Syntax.Common.WithHiding a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Common.WithHiding a)
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.Hiding
instance Agda.Utils.Null.Null Agda.Syntax.Common.Hiding
instance GHC.Base.Semigroup Agda.Syntax.Common.Hiding
instance GHC.Base.Monoid Agda.Syntax.Common.Hiding
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.Hiding
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.Hiding
instance Control.DeepSeq.NFData Agda.Syntax.Common.Hiding
instance Agda.Syntax.Common.HasOverlapMode Agda.Syntax.Common.OverlapMode
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.OverlapMode
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.OverlapMode
instance Control.DeepSeq.NFData Agda.Syntax.Common.OverlapMode
instance GHC.Base.Semigroup Agda.Syntax.Common.Overlappable
instance GHC.Base.Monoid Agda.Syntax.Common.Overlappable
instance Control.DeepSeq.NFData Agda.Syntax.Common.Overlappable
instance Agda.Syntax.Common.CopatternMatchingAllowed Agda.Syntax.Common.PatternOrCopattern
instance Agda.Syntax.Common.CopatternMatchingAllowed Agda.Syntax.Common.HasEta
instance Agda.Syntax.Common.PatternMatchingAllowed Agda.Syntax.Common.PatternOrCopattern
instance Agda.Syntax.Common.PatternMatchingAllowed Agda.Syntax.Common.HasEta
instance Agda.Syntax.Common.PatternMatchingAllowed Agda.Syntax.Common.Aspect.Induction
instance Control.DeepSeq.NFData Agda.Syntax.Common.PatternOrCopattern
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.PatternOrCopattern
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.PatternOrCopattern
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange (Agda.Syntax.Common.HasEta' a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Syntax.Common.HasEta' a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Common.HasEta' a)
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.Language
instance Control.DeepSeq.NFData Agda.Syntax.Common.Language
instance Control.DeepSeq.NFData Agda.Syntax.Common.Cubical
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.FileType
instance Control.DeepSeq.NFData Agda.Syntax.Common.FileType
instance GHC.Base.Semigroup Agda.Syntax.Common.IsMain
instance GHC.Base.Monoid Agda.Syntax.Common.IsMain
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.Aspect.Induction
instance Agda.Syntax.Position.HasRange Agda.Syntax.Common.Aspect.Induction
instance Agda.Syntax.Position.KillRange Agda.Syntax.Common.Aspect.Induction


-- | Preprocessors for literate code formats.
module Agda.Syntax.Parser.Literate

-- | List of valid extensions for literate Agda files, and their
--   corresponding preprocessors.
--   
--   If you add new extensions, remember to update test/Utils.hs so that
--   test cases ending in the new extensions are found.
literateProcessors :: [(String, (Processor, FileType))]

-- | Short list of extensions for literate Agda files. For display
--   purposes.
literateExtsShortList :: [String]
literateSrcFile :: [Layer] -> SrcFile

-- | Preprocessor for literate TeX.
literateTeX :: Position -> String -> [Layer]

-- | Preprocessor for reStructuredText.
literateRsT :: Position -> String -> [Layer]

-- | Preprocessor for Markdown.
literateMd :: Position -> String -> [Layer]

-- | Preprocessor for Org mode documents.
literateOrg :: Position -> String -> [Layer]

-- | Blanks the non-code parts of a given file, preserving positions of
--   characters corresponding to code. This way, there is a direct
--   correspondence between source positions and positions in the processed
--   result.
illiterate :: [Layer] -> String
atomizeLayers :: Layers -> [(LayerRole, Char)]

-- | Type of a literate preprocessor: Invariants:
--   
--   <pre>
--   f : Processor
--   </pre>
--   
--   proposition&gt; f pos s /= []
--   
--   proposition&gt; f pos s &gt;&gt;= layerContent == s
type Processor = Position -> String -> [Layer]

-- | A list of contiguous layers.
type Layers = [Layer]

-- | A sequence of characters in a file playing the same role.
data Layer
Layer :: LayerRole -> Interval -> String -> Layer
[layerRole] :: Layer -> LayerRole
[interval] :: Layer -> Interval
[layerContent] :: Layer -> String

-- | Role of a character in the file.
data LayerRole
Markup :: LayerRole
Comment :: LayerRole
Code :: LayerRole

-- | Returns <tt>True</tt> if the role corresponds to Agda code.
isCode :: LayerRole -> Bool

-- | Returns <tt>True</tt> if the layer contains Agda code.
isCodeLayer :: Layer -> Bool
instance GHC.Classes.Eq Agda.Syntax.Parser.Literate.LayerRole
instance GHC.Show.Show Agda.Syntax.Parser.Literate.LayerRole
instance GHC.Show.Show Agda.Syntax.Parser.Literate.Layer
instance Agda.Syntax.Position.HasRange Agda.Syntax.Parser.Literate.Layer


-- | Definitions for fixity, precedence levels, and declared syntax.
module Agda.Syntax.Fixity

-- | Decorating something with <tt>Fixity'</tt>.
data ThingWithFixity x
ThingWithFixity :: x -> Fixity' -> ThingWithFixity x

-- | Do we prefer parens around arguments like <tt>λ x → x</tt> or not? See
--   <a>lamBrackets</a>.
data ParenPreference
PreferParen :: ParenPreference
PreferParenless :: ParenPreference
preferParen :: ParenPreference -> Bool
preferParenless :: ParenPreference -> Bool

-- | Precedence is associated with a context.
data Precedence
TopCtx :: Precedence
FunctionSpaceDomainCtx :: Precedence
LeftOperandCtx :: Fixity -> Precedence
RightOperandCtx :: Fixity -> ParenPreference -> Precedence
FunctionCtx :: Precedence
ArgumentCtx :: ParenPreference -> Precedence
InsideOperandCtx :: Precedence
WithFunCtx :: Precedence
WithArgCtx :: Precedence
DotPatternCtx :: Precedence

-- | When printing we keep track of a stack of precedences in order to be
--   able to decide whether it's safe to leave out parens around lambdas.
--   An empty stack is equivalent to <a>TopCtx</a>. Invariant: `notElem
--   TopCtx`.
type PrecedenceStack = [Precedence]
pushPrecedence :: Precedence -> PrecedenceStack -> PrecedenceStack
headPrecedence :: PrecedenceStack -> Precedence

-- | Argument context preferring parens.
argumentCtx_ :: Precedence

-- | Do we need to bracket an operator application of the given fixity in a
--   context with the given precedence.
opBrackets :: Fixity -> PrecedenceStack -> Bool

-- | Do we need to bracket an operator application of the given fixity in a
--   context with the given precedence.
opBrackets' :: Bool -> Fixity -> PrecedenceStack -> Bool

-- | Does a lambda-like thing (lambda, let or pi) need brackets in the
--   given context? A peculiar thing with lambdas is that they don't need
--   brackets in certain right operand contexts. To decide we need to look
--   at the stack of precedences and not just the current precedence.
--   Example: <tt>m₁ &gt;&gt;= (λ x → x) &gt;&gt;= m₂</tt> (for
--   <tt>_&gt;&gt;=_</tt> left associative).
lamBrackets :: PrecedenceStack -> Bool

-- | Does a function application need brackets?
appBrackets :: PrecedenceStack -> Bool

-- | Does a function application need brackets?
appBrackets' :: Bool -> PrecedenceStack -> Bool

-- | Does a with application need brackets?
withAppBrackets :: PrecedenceStack -> Bool

-- | Does a function space need brackets?
piBrackets :: PrecedenceStack -> Bool
roundFixBrackets :: PrecedenceStack -> Bool
instance GHC.Show.Show x => GHC.Show.Show (Agda.Syntax.Fixity.ThingWithFixity x)
instance Data.Traversable.Traversable Agda.Syntax.Fixity.ThingWithFixity
instance Data.Foldable.Foldable Agda.Syntax.Fixity.ThingWithFixity
instance GHC.Base.Functor Agda.Syntax.Fixity.ThingWithFixity
instance GHC.Generics.Generic Agda.Syntax.Fixity.ParenPreference
instance GHC.Show.Show Agda.Syntax.Fixity.ParenPreference
instance GHC.Classes.Ord Agda.Syntax.Fixity.ParenPreference
instance GHC.Classes.Eq Agda.Syntax.Fixity.ParenPreference
instance GHC.Generics.Generic Agda.Syntax.Fixity.Precedence
instance GHC.Classes.Eq Agda.Syntax.Fixity.Precedence
instance GHC.Show.Show Agda.Syntax.Fixity.Precedence
instance Control.DeepSeq.NFData Agda.Syntax.Fixity.Precedence
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Fixity.Precedence
instance Control.DeepSeq.NFData Agda.Syntax.Fixity.ParenPreference
instance Agda.Syntax.Common.LensFixity' (Agda.Syntax.Fixity.ThingWithFixity a)
instance Agda.Syntax.Common.LensFixity (Agda.Syntax.Fixity.ThingWithFixity a)
instance Agda.Syntax.Position.KillRange x => Agda.Syntax.Position.KillRange (Agda.Syntax.Fixity.ThingWithFixity x)


-- | The parser monad used by the operator parser
module Agda.Syntax.Concrete.Operators.Parser.Monad

-- | Memoisation keys.
data MemoKey
NodeK :: PrecedenceKey -> MemoKey
PostLeftsK :: PrecedenceKey -> MemoKey
PreRightsK :: PrecedenceKey -> MemoKey
TopK :: MemoKey
AppK :: MemoKey
NonfixK :: MemoKey
type PrecedenceKey = Either PrecedenceLevel PrecedenceLevel

-- | The parser monad.
type Parser tok a = Parser MemoKey tok (MaybePlaceholder tok) a

-- | Runs the parser.
parse :: forall tok a. Parser tok a -> [MaybePlaceholder tok] -> [a]

-- | Parses a token satisfying the given predicate. The computed value is
--   returned.
sat' :: (MaybePlaceholder tok -> Maybe a) -> Parser tok a

-- | Parses a token satisfying the given predicate.
sat :: (MaybePlaceholder tok -> Bool) -> Parser tok (MaybePlaceholder tok)

-- | Uses the given document as the printed representation of the given
--   parser. The document's precedence is taken to be <tt>atomP</tt>.
doc :: Doc -> Parser tok a -> Parser tok a

-- | Memoises the given parser.
--   
--   Every memoised parser must be annotated with a <i>unique</i> key.
--   (Parametrised parsers must use distinct keys for distinct inputs.)
memoise :: MemoKey -> Parser tok tok -> Parser tok tok

-- | Memoises the given parser, but only if printing, not if parsing.
--   
--   Every memoised parser must be annotated with a <i>unique</i> key.
--   (Parametrised parsers must use distinct keys for distinct inputs.)
memoiseIfPrinting :: MemoKey -> Parser tok tok -> Parser tok tok

-- | Tries to print the parser, or returns <tt>empty</tt>, depending on the
--   implementation. This function might not terminate.
grammar :: Parser tok a -> Doc
instance GHC.Generics.Generic Agda.Syntax.Concrete.Operators.Parser.Monad.MemoKey
instance GHC.Show.Show Agda.Syntax.Concrete.Operators.Parser.Monad.MemoKey
instance GHC.Classes.Eq Agda.Syntax.Concrete.Operators.Parser.Monad.MemoKey
instance Data.Hashable.Class.Hashable Agda.Syntax.Concrete.Operators.Parser.Monad.MemoKey


-- | Names in the concrete syntax are just strings (or lists of strings for
--   qualified names).
module Agda.Syntax.Concrete.Name

-- | A name is a non-empty list of alternating <a>Id</a>s and <a>Hole</a>s.
--   A normal name is represented by a singleton list, and operators are
--   represented by a list with <a>Hole</a>s where the arguments should go.
--   For instance: <tt>[Hole,Id "+",Hole]</tt> is infix addition.
--   
--   Equality and ordering on <tt>Name</tt>s are defined to ignore range so
--   same names in different locations are equal.
data Name

-- | A (mixfix) identifier.
Name :: Range -> NameInScope -> NameParts -> Name
[nameRange] :: Name -> Range
[nameInScope] :: Name -> NameInScope
[nameNameParts] :: Name -> NameParts

-- | <tt>_</tt>.
NoName :: Range -> NameId -> Name
[nameRange] :: Name -> Range
[nameId] :: Name -> NameId
type NameParts = List1 NamePart

-- | An open mixfix identifier is either prefix, infix, or suffix. That is
--   to say: at least one of its extremities is a <tt>Hole</tt>
isOpenMixfix :: Name -> Bool

-- | Mixfix identifiers are composed of words and holes, e.g. <tt>_+_</tt>
--   or <tt>if_then_else_</tt> or <tt>[_/_]</tt>.
data NamePart

-- | <tt>_</tt> part.
Hole :: NamePart

-- | Identifier part.
Id :: RawName -> NamePart

-- | <tt>QName</tt> is a list of namespaces and the name of the constant.
--   For the moment assumes namespaces are just <tt>Name</tt>s and not
--   explicitly applied modules. Also assumes namespaces are generative by
--   just using derived equality. We will have to define an equality
--   instance to non-generative namespaces (as well as having some sort of
--   lookup table for namespace names).
data QName

-- | <tt>A.rest</tt>.
Qual :: Name -> QName -> QName

-- | <tt>x</tt>.
QName :: Name -> QName

-- | Create an ordinary <a>InScope</a> name.
simpleName :: RawName -> Name

-- | Create a binary operator name in scope.
simpleBinaryOperator :: RawName -> Name

-- | Create an ordinary <a>InScope</a> name containing a single
--   <a>Hole</a>.
simpleHole :: Name

-- | Don't use on 'NoName{}'.
lensNameParts :: Lens' Name NameParts
nameToRawName :: Name -> RawName
nameParts :: Name -> NameParts
nameStringParts :: Name -> [RawName]

-- | Parse a string to parts of a concrete name.
--   
--   Note: <tt>stringNameParts "_" == [Id "_"] == nameParts NoName{}</tt>
stringNameParts :: String -> NameParts

-- | Number of holes in a <a>Name</a> (i.e., arity of a mixfix-operator).
class NumHoles a
numHoles :: NumHoles a => a -> Int

-- | Is the name an operator? Needs at least 2 <a>NamePart</a>s.
isOperator :: Name -> Bool
isHole :: NamePart -> Bool
isPrefix :: Name -> Bool
isPostfix :: Name -> Bool
isInfix :: Name -> Bool
isNonfix :: Name -> Bool
data NameInScope
InScope :: NameInScope
NotInScope :: NameInScope
class LensInScope a
lensInScope :: LensInScope a => Lens' a NameInScope
isInScope :: LensInScope a => a -> NameInScope
mapInScope :: LensInScope a => (NameInScope -> NameInScope) -> a -> a
setInScope :: LensInScope a => a -> a
setNotInScope :: LensInScope a => a -> a

-- | Method by which to generate fresh unshadowed names.
data FreshNameMode

-- | Append an integer Unicode subscript: x, x₁, x₂, …
UnicodeSubscript :: FreshNameMode

-- | Append an integer ASCII counter: x, x1, x2, …
AsciiCounter :: FreshNameMode
nextRawName :: FreshNameMode -> RawName -> RawName

-- | Get the next version of the concrete name. For instance, <tt>nextName
--   "x" = "x₁"</tt>. The name must not be a <a>NoName</a>.
nextName :: FreshNameMode -> Name -> Name

-- | Zoom on the last non-hole in a name.
lastIdPart :: Lens' NameParts RawName

-- | Get the first version of the concrete name that does not satisfy the
--   given predicate.
firstNonTakenName :: FreshNameMode -> (Name -> Bool) -> Name -> Name

-- | Lens for accessing and modifying the suffix of a name. The suffix of a
--   <tt>NoName</tt> is always <tt>Nothing</tt>, and should not be changed.
nameSuffix :: Lens' Name (Maybe Suffix)

-- | Split a name into a base name plus a suffix.
nameSuffixView :: Name -> (Maybe Suffix, Name)

-- | Replaces the suffix of a name. Unless the suffix is <tt>Nothing</tt>,
--   the name should not be <tt>NoName</tt>.
setNameSuffix :: Maybe Suffix -> Name -> Name

-- | Get a raw version of the name with all suffixes removed. For instance,
--   <tt>nameRoot "x₁₂₃" = "x"</tt>.
nameRoot :: Name -> RawName
sameRoot :: Name -> Name -> Bool

-- | Lens for the unqualified part of a QName
lensQNameName :: Lens' QName Name

-- | <pre>
--   qualify A.B x == A.B.x
--   </pre>
qualify :: QName -> Name -> QName

-- | <pre>
--   unqualify A.B.x == x
--   </pre>
--   
--   The range is preserved.
unqualify :: QName -> Name

-- | <pre>
--   qnameParts A.B.x = [A, B, x]
--   </pre>
qnameParts :: QName -> List1 Name

-- | Is the name (un)qualified?
isQualified :: QName -> Bool
isUnqualified :: QName -> Maybe Name

-- | <pre>
--   noName_ = <a>noName</a> <a>noRange</a>
--   </pre>
noName_ :: Name
noName :: Range -> Name

-- | Check whether a name is the empty name "_".
class IsNoName a
isNoName :: IsNoName a => a -> Bool
isNoName :: (IsNoName a, Foldable t, IsNoName b, t b ~ a) => a -> Bool
instance GHC.Generics.Generic Agda.Syntax.Concrete.Name.NamePart
instance GHC.Show.Show Agda.Syntax.Concrete.Name.NameInScope
instance GHC.Classes.Eq Agda.Syntax.Concrete.Name.NameInScope
instance GHC.Classes.Ord Agda.Syntax.Concrete.Name.QName
instance GHC.Classes.Eq Agda.Syntax.Concrete.Name.QName
instance GHC.Show.Show Agda.Syntax.Concrete.Name.Name
instance GHC.Show.Show Agda.Syntax.Concrete.Name.NamePart
instance GHC.Show.Show Agda.Syntax.Concrete.Name.QName
instance Agda.Syntax.Concrete.Name.IsNoName GHC.Base.String
instance Agda.Syntax.Concrete.Name.IsNoName Data.ByteString.Internal.Type.ByteString
instance Agda.Syntax.Concrete.Name.IsNoName Agda.Syntax.Concrete.Name.Name
instance Agda.Syntax.Concrete.Name.IsNoName Agda.Syntax.Concrete.Name.QName
instance Agda.Syntax.Concrete.Name.IsNoName a => Agda.Syntax.Concrete.Name.IsNoName (Agda.Syntax.Common.Ranged a)
instance Agda.Syntax.Concrete.Name.IsNoName a => Agda.Syntax.Concrete.Name.IsNoName (Agda.Syntax.Common.WithOrigin a)
instance Agda.Syntax.Concrete.Name.LensInScope Agda.Syntax.Concrete.Name.NameInScope
instance Agda.Syntax.Concrete.Name.LensInScope Agda.Syntax.Concrete.Name.Name
instance Agda.Syntax.Concrete.Name.LensInScope Agda.Syntax.Concrete.Name.QName
instance Agda.Syntax.Common.Underscore Agda.Syntax.Concrete.Name.QName
instance Agda.Syntax.Concrete.Name.NumHoles Agda.Syntax.Concrete.Name.QName
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.Name.QName
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.Name.QName
instance Agda.Syntax.Position.SetRange Agda.Syntax.Concrete.Name.QName
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.Name.QName
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.Name.QName
instance Agda.Syntax.Common.Underscore Agda.Syntax.Concrete.Name.Name
instance GHC.Classes.Eq Agda.Syntax.Concrete.Name.Name
instance GHC.Classes.Ord Agda.Syntax.Concrete.Name.Name
instance Agda.Syntax.Concrete.Name.NumHoles Agda.Syntax.Concrete.Name.Name
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.Name.Name
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.Name.Name
instance Agda.Syntax.Position.SetRange Agda.Syntax.Concrete.Name.Name
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.Name.Name
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.Name.Name
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.Name.NameInScope
instance Agda.Syntax.Concrete.Name.NumHoles Agda.Syntax.Concrete.Name.NameParts
instance GHC.Classes.Eq Agda.Syntax.Concrete.Name.NamePart
instance GHC.Classes.Ord Agda.Syntax.Concrete.Name.NamePart
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.Name.NamePart
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.Name.NamePart


-- | Abstract names carry unique identifiers and stuff.
module Agda.Syntax.Abstract.Name

-- | A name is a unique identifier and a suggestion for a concrete name.
--   The concrete name contains the source location (if any) of the name.
--   The source location of the binding site is also recorded.
data Name
Name :: !NameId -> Name -> Name -> Range -> Fixity' -> Bool -> Name
[nameId] :: Name -> !NameId

-- | The concrete name used for this instance
[nameConcrete] :: Name -> Name

-- | The concrete name in the original definition (needed by primShowQName,
--   see #4735)
[nameCanonical] :: Name -> Name
[nameBindingSite] :: Name -> Range
[nameFixity] :: Name -> Fixity'

-- | Is this the name of the invisible record variable <tt>self</tt>?
--   Should not be printed or displayed in the context, see issue #3584.
[nameIsRecordName] :: Name -> Bool

-- | Qualified names are non-empty lists of names. Equality on qualified
--   names are just equality on the last name, i.e. the module part is just
--   for show.
--   
--   The <a>SetRange</a> instance for qualified names sets all individual
--   ranges (including those of the module prefix) to the given one.
data QName
QName :: ModuleName -> Name -> QName
[qnameModule] :: QName -> ModuleName
[qnameName] :: QName -> Name

-- | Check whether we are a projection pattern.
class IsProjP a
isProjP :: IsProjP a => a -> Maybe (ProjOrigin, AmbiguousQName)

-- | A name suffix
data Suffix
NoSuffix :: Suffix
Suffix :: !Integer -> Suffix

-- | Something preceeded by a qualified name.
data QNamed a
QNamed :: QName -> a -> QNamed a
[qname] :: QNamed a -> QName
[qnamed] :: QNamed a -> a

-- | A module name is just a qualified name.
--   
--   The <a>SetRange</a> instance for module names sets all individual
--   ranges to the given one.
newtype ModuleName
MName :: [Name] -> ModuleName
[mnameToList] :: ModuleName -> [Name]

-- | Ambiguous qualified names. Used for overloaded constructors.
--   
--   Invariant: All the names in the list must have the same concrete,
--   unqualified name. (This implies that they all have the same
--   <a>Range'</a>).
newtype AmbiguousQName
AmbQ :: List1 QName -> AmbiguousQName
[unAmbQ] :: AmbiguousQName -> List1 QName

-- | Make a <a>Name</a> from some kind of string.
class MkName a

-- | The <a>Range'</a> sets the <i>definition site</i> of the name, not the
--   use site.
mkName :: MkName a => Range -> NameId -> a -> Name
mkName_ :: MkName a => NameId -> a -> Name

-- | Get the next version of the concrete name. For instance, <tt>nextName
--   "x" = "x₁"</tt>. The name must not be a <tt>NoName</tt>.
nextName :: FreshNameMode -> Name -> Name
qualify :: ModuleName -> Name -> QName

-- | A singleton "ambiguous" name.
unambiguous :: QName -> AmbiguousQName

-- | Is the name an operator?
isOperator :: QName -> Bool
sameRoot :: Name -> Name -> Bool
lensQNameName :: Lens' QName Name

-- | Useful for debugging scoping problems
uglyShowName :: Name -> String

-- | Get the first of the ambiguous names.
headAmbQ :: AmbiguousQName -> QName

-- | Is a name ambiguous.
isAmbiguous :: AmbiguousQName -> Bool

-- | Get the name if unambiguous.
getUnambiguous :: AmbiguousQName -> Maybe QName

-- | A module is anonymous if the qualification path ends in an underscore.
isAnonymousModuleName :: ModuleName -> Bool

-- | Sets the ranges of the individual names in the module name to match
--   those of the corresponding concrete names. If the concrete names are
--   fewer than the number of module name name parts, then the initial name
--   parts get the range <a>noRange</a>.
--   
--   <tt>C.D.E `withRangesOf` [A, B]</tt> returns <tt>C.D.E</tt> but with
--   ranges set as follows:
--   
--   <ul>
--   <li><tt>C</tt>: <a>noRange</a>.</li>
--   <li><tt>D</tt>: the range of <tt>A</tt>.</li>
--   <li><tt>E</tt>: the range of <tt>B</tt>.</li>
--   </ul>
--   
--   Precondition: The number of module name name parts has to be at least
--   as large as the length of the list.
withRangesOf :: ModuleName -> List1 Name -> ModuleName

-- | Like <a>withRangesOf</a>, but uses the name parts (qualifier + name)
--   of the qualified name as the list of concrete names.
withRangesOfQ :: ModuleName -> QName -> ModuleName
mnameFromList :: [Name] -> ModuleName
mnameFromList1 :: List1 Name -> ModuleName
mnameToList1 :: ModuleName -> List1 Name
noModuleName :: ModuleName
commonParentModule :: ModuleName -> ModuleName -> ModuleName
makeName :: NameId -> Name -> Range -> Fixity' -> Bool -> Name
qnameToList0 :: QName -> [Name]
qnameToList :: QName -> List1 Name
qnameFromList :: List1 Name -> QName
qnameToMName :: QName -> ModuleName
mnameToQName :: ModuleName -> QName
showQNameId :: QName -> String

-- | Turn a qualified name into a concrete name. This should only be used
--   as a fallback when looking up the right concrete name in the scope
--   fails.
qnameToConcrete :: QName -> QName
mnameToConcrete :: ModuleName -> QName
qualifyM :: ModuleName -> ModuleName -> ModuleName
qualifyQ :: ModuleName -> QName -> QName

-- | Convert a <a>Name</a> to a <a>QName</a> (add no module name).
qualify_ :: Name -> QName

-- | Is the first module a weak parent of the second?
isLeParentModuleOf :: ModuleName -> ModuleName -> Bool

-- | Is the first module a proper parent of the second?
isLtParentModuleOf :: ModuleName -> ModuleName -> Bool

-- | Is the first module a weak child of the second?
isLeChildModuleOf :: ModuleName -> ModuleName -> Bool

-- | Is the first module a proper child of the second?
isLtChildModuleOf :: ModuleName -> ModuleName -> Bool
isInModule :: QName -> ModuleName -> Bool
nameToArgName :: Name -> ArgName
namedArgName :: NamedArg Name -> ArgName

-- | Check whether a name is the empty name "_".
class IsNoName a
isNoName :: IsNoName a => a -> Bool
isNoName :: (IsNoName a, Foldable t, IsNoName b, t b ~ a) => a -> Bool

-- | Method by which to generate fresh unshadowed names.
data FreshNameMode

-- | Append an integer Unicode subscript: x, x₁, x₂, …
UnicodeSubscript :: FreshNameMode

-- | Append an integer ASCII counter: x, x1, x2, …
AsciiCounter :: FreshNameMode
instance GHC.Classes.Ord Agda.Syntax.Abstract.Name.ModuleName
instance GHC.Classes.Eq Agda.Syntax.Abstract.Name.ModuleName
instance Data.Traversable.Traversable Agda.Syntax.Abstract.Name.QNamed
instance Data.Foldable.Foldable Agda.Syntax.Abstract.Name.QNamed
instance GHC.Base.Functor Agda.Syntax.Abstract.Name.QNamed
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.Name.AmbiguousQName
instance GHC.Classes.Ord Agda.Syntax.Abstract.Name.AmbiguousQName
instance GHC.Classes.Eq Agda.Syntax.Abstract.Name.AmbiguousQName
instance GHC.Classes.Ord Agda.Syntax.Abstract.Name.Suffix
instance GHC.Classes.Eq Agda.Syntax.Abstract.Name.Suffix
instance GHC.Show.Show Agda.Syntax.Abstract.Name.Suffix
instance GHC.Show.Show Agda.Syntax.Abstract.Name.Name
instance GHC.Show.Show Agda.Syntax.Abstract.Name.ModuleName
instance GHC.Show.Show Agda.Syntax.Abstract.Name.QName
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Abstract.Name.QNamed a)
instance GHC.Show.Show Agda.Syntax.Abstract.Name.AmbiguousQName
instance Agda.Syntax.Abstract.Name.MkName GHC.Base.String
instance Agda.Syntax.Abstract.Name.IsProjP a => Agda.Syntax.Abstract.Name.IsProjP (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Abstract.Name.IsProjP a => Agda.Syntax.Abstract.Name.IsProjP (Agda.Syntax.Common.Named n a)
instance Agda.Syntax.Abstract.Name.IsProjP GHC.Base.Void
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.Name.Suffix
instance Agda.Syntax.Concrete.Name.NumHoles Agda.Syntax.Abstract.Name.AmbiguousQName
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Abstract.Name.AmbiguousQName
instance Agda.Syntax.Position.HasRange Agda.Syntax.Abstract.Name.AmbiguousQName
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.Name.AmbiguousQName
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Abstract.Name.QNamed a)
instance GHC.Classes.Eq Agda.Syntax.Abstract.Name.QName
instance GHC.Classes.Ord Agda.Syntax.Abstract.Name.QName
instance Data.Hashable.Class.Hashable Agda.Syntax.Abstract.Name.QName
instance Agda.Syntax.Concrete.Name.NumHoles Agda.Syntax.Abstract.Name.QName
instance Agda.Syntax.Common.LensFixity' Agda.Syntax.Abstract.Name.QName
instance Agda.Syntax.Common.LensFixity Agda.Syntax.Abstract.Name.QName
instance Agda.Syntax.Concrete.Name.LensInScope Agda.Syntax.Abstract.Name.QName
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Abstract.Name.QName
instance Agda.Syntax.Position.HasRange Agda.Syntax.Abstract.Name.QName
instance Agda.Syntax.Position.SetRange Agda.Syntax.Abstract.Name.QName
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.Name.QName
instance Agda.Utils.Size.Sized Agda.Syntax.Abstract.Name.QName
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.Name.QName
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Abstract.Name.ModuleName
instance Agda.Syntax.Position.HasRange Agda.Syntax.Abstract.Name.ModuleName
instance Agda.Syntax.Position.SetRange Agda.Syntax.Abstract.Name.ModuleName
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.Name.ModuleName
instance Agda.Utils.Size.Sized Agda.Syntax.Abstract.Name.ModuleName
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.Name.ModuleName
instance GHC.Classes.Eq Agda.Syntax.Abstract.Name.Name
instance GHC.Classes.Ord Agda.Syntax.Abstract.Name.Name
instance Data.Hashable.Class.Hashable Agda.Syntax.Abstract.Name.Name
instance Agda.Syntax.Concrete.Name.IsNoName Agda.Syntax.Abstract.Name.Name
instance Agda.Syntax.Concrete.Name.NumHoles Agda.Syntax.Abstract.Name.Name
instance Agda.Syntax.Common.LensFixity' Agda.Syntax.Abstract.Name.Name
instance Agda.Syntax.Common.LensFixity Agda.Syntax.Abstract.Name.Name
instance Agda.Syntax.Concrete.Name.LensInScope Agda.Syntax.Abstract.Name.Name
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Abstract.Name.Name
instance Agda.Syntax.Position.HasRange Agda.Syntax.Abstract.Name.Name
instance Agda.Syntax.Position.SetRange Agda.Syntax.Abstract.Name.Name
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.Name.Name
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.Name.Name


-- | Occurrences.
module Agda.TypeChecking.Positivity.Occurrence

-- | Subterm occurrences for positivity checking. The constructors are
--   listed in increasing information they provide: <tt>Mixed &lt;= JustPos
--   &lt;= StrictPos &lt;= GuardPos &lt;= Unused</tt> <tt>Mixed &lt;=
--   JustNeg &lt;= Unused</tt>.
data Occurrence

-- | Arbitrary occurrence (positive and negative).
Mixed :: Occurrence

-- | Negative occurrence.
JustNeg :: Occurrence

-- | Positive occurrence, but not strictly positive.
JustPos :: Occurrence

-- | Strictly positive occurrence.
StrictPos :: Occurrence

-- | Guarded strictly positive occurrence (i.e., under ∞). For checking
--   recursive records.
GuardPos :: Occurrence
Unused :: Occurrence

-- | Description of an occurrence.
data OccursWhere

-- | The elements of the sequences, read from left to right, explain how to
--   get to the occurrence. The second sequence includes the main
--   information, and if the first sequence is non-empty, then it includes
--   information about the context of the second sequence.
OccursWhere :: Range -> Seq Where -> Seq Where -> OccursWhere

-- | One part of the description of an occurrence.
data Where
LeftOfArrow :: Where

-- | in the nth argument of a define constant
DefArg :: QName -> Nat -> Where

-- | in the principal argument of built-in ∞
UnderInf :: Where

-- | as an argument to a bound variable
VarArg :: Where

-- | as an argument of a metavariable
MetaArg :: Where

-- | in the type of a constructor
ConArgType :: QName -> Where

-- | in a datatype index of a constructor
IndArgType :: QName -> Where

-- | in an endpoint of a higher constructor
ConEndpoint :: QName -> Where

-- | in the nth clause of a defined function
InClause :: Nat -> Where

-- | matched against in a clause of a defined function
Matched :: Where

-- | is an index of an inductive family
IsIndex :: Where

-- | in the definition of a constant
InDefOf :: QName -> Where

-- | The map contains bindings of the form <tt>bound |-&gt; ess</tt>,
--   satisfying the following property: for every non-empty list
--   <tt>w</tt>, <tt><a>foldr1</a> <a>otimes</a> w <a>&lt;=</a> bound</tt>
--   iff <tt><a>or</a> [ <a>all</a> every w <a>&amp;&amp;</a> <a>any</a>
--   some w | (every, some) &lt;- ess ]</tt>.
boundToEverySome :: Map Occurrence [(Occurrence -> Bool, Occurrence -> Bool)]

-- | <tt>productOfEdgesInBoundedWalk occ g u v bound</tt> returns a value
--   distinct from <a>Nothing</a> iff there is a walk <tt>c</tt> (a list of
--   edges) in <tt>g</tt>, from <tt>u</tt> to <tt>v</tt>, for which the
--   product <tt><a>foldr1</a> <a>otimes</a> (<a>map</a> occ c)
--   <a>&lt;=</a> bound</tt>. In this case the returned value is
--   <tt><a>Just</a> (<a>foldr1</a> <a>otimes</a> c)</tt> for one such walk
--   <tt>c</tt>.
--   
--   Preconditions: <tt>u</tt> and <tt>v</tt> must belong to <tt>g</tt>,
--   and <tt>bound</tt> must belong to the domain of
--   <tt>boundToEverySome</tt>.
productOfEdgesInBoundedWalk :: (SemiRing e, Ord n) => (e -> Occurrence) -> Graph n e -> n -> n -> Occurrence -> Maybe e
instance GHC.Generics.Generic Agda.TypeChecking.Positivity.Occurrence.Where
instance GHC.Classes.Ord Agda.TypeChecking.Positivity.Occurrence.Where
instance GHC.Classes.Eq Agda.TypeChecking.Positivity.Occurrence.Where
instance GHC.Show.Show Agda.TypeChecking.Positivity.Occurrence.Where
instance GHC.Generics.Generic Agda.TypeChecking.Positivity.Occurrence.OccursWhere
instance GHC.Classes.Ord Agda.TypeChecking.Positivity.Occurrence.OccursWhere
instance GHC.Classes.Eq Agda.TypeChecking.Positivity.Occurrence.OccursWhere
instance GHC.Show.Show Agda.TypeChecking.Positivity.Occurrence.OccursWhere
instance GHC.Enum.Bounded Agda.TypeChecking.Positivity.Occurrence.Occurrence
instance GHC.Enum.Enum Agda.TypeChecking.Positivity.Occurrence.Occurrence
instance GHC.Classes.Ord Agda.TypeChecking.Positivity.Occurrence.Occurrence
instance GHC.Classes.Eq Agda.TypeChecking.Positivity.Occurrence.Occurrence
instance GHC.Show.Show Agda.TypeChecking.Positivity.Occurrence.Occurrence
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Positivity.Occurrence.Occurrence
instance Control.DeepSeq.NFData Agda.TypeChecking.Positivity.Occurrence.Occurrence
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Positivity.Occurrence.Occurrence
instance Agda.Utils.SemiRing.SemiRing Agda.TypeChecking.Positivity.Occurrence.Occurrence
instance Agda.Utils.SemiRing.StarSemiRing Agda.TypeChecking.Positivity.Occurrence.Occurrence
instance Agda.Utils.Null.Null Agda.TypeChecking.Positivity.Occurrence.Occurrence
instance Control.DeepSeq.NFData Agda.TypeChecking.Positivity.Occurrence.OccursWhere
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Positivity.Occurrence.OccursWhere
instance Agda.Utils.Size.Sized Agda.TypeChecking.Positivity.Occurrence.OccursWhere
instance Control.DeepSeq.NFData Agda.TypeChecking.Positivity.Occurrence.Where
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Positivity.Occurrence.Where


-- | Types related to warnings raised by Agda.
module Agda.TypeChecking.Monad.Base.Warning
data RecordFieldWarning

-- | Each redundant field comes with a range of associated dead code.
DuplicateFields :: [(Name, Range)] -> RecordFieldWarning

-- | Record type, fields not supplied by user, non-fields but supplied. The
--   redundant fields come with a range of associated dead code.
TooManyFields :: QName -> [Name] -> [(Name, Range)] -> RecordFieldWarning
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.Warning.RecordFieldWarning
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.Warning.RecordFieldWarning

module Agda.Syntax.Literal
type RLiteral = Ranged Literal
data Literal
LitNat :: !Integer -> Literal
LitWord64 :: !Word64 -> Literal
LitFloat :: !Double -> Literal
LitString :: !Text -> Literal
LitChar :: !Char -> Literal
LitQName :: !QName -> Literal
LitMeta :: !TopLevelModuleName' Range -> !MetaId -> Literal
showText :: Text -> ShowS
showChar' :: Char -> ShowS
instance GHC.Show.Show Agda.Syntax.Literal.Literal
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Literal.Literal
instance GHC.Classes.Eq Agda.Syntax.Literal.Literal
instance GHC.Classes.Ord Agda.Syntax.Literal.Literal
instance Agda.Syntax.Position.KillRange Agda.Syntax.Literal.Literal
instance Control.DeepSeq.NFData Agda.Syntax.Literal.Literal


-- | The treeless syntax is intended to be used as input for the compiler
--   backends. It is more low-level than Internal syntax and is not used
--   for type checking.
--   
--   Some of the features of treeless syntax are: - case expressions
--   instead of case trees - no instantiated datatypes / constructors
module Agda.Syntax.Treeless
type Args = [TTerm]

-- | Usage status of function arguments in treeless code.
data ArgUsage
ArgUsed :: ArgUsage
ArgUnused :: ArgUsage

-- | Treeless Term. All local variables are using de Bruijn indices.
data TTerm
TVar :: Int -> TTerm
TPrim :: TPrim -> TTerm
TDef :: QName -> TTerm
TApp :: TTerm -> Args -> TTerm
TLam :: TTerm -> TTerm
TLit :: Literal -> TTerm
TCon :: QName -> TTerm

-- | introduces a new (non-recursive) local binding. The bound term MUST
--   only be evaluated if it is used inside the body. Sharing may happen,
--   but is optional. It is also perfectly valid to just inline the bound
--   term in the body.
TLet :: TTerm -> TTerm -> TTerm

-- | Case scrutinee (always variable), case type, default value,
--   alternatives First, all TACon alternatives are tried; then all TAGuard
--   alternatives in top to bottom order. TACon alternatives must not
--   overlap.
TCase :: Int -> CaseInfo -> TTerm -> [TAlt] -> TTerm
TUnit :: TTerm
TSort :: TTerm
TErased :: TTerm

-- | Used by the GHC backend
TCoerce :: TTerm -> TTerm

-- | A runtime error, something bad has happened.
TError :: TError -> TTerm

-- | The treeless compiler can behave differently depending on the target
--   language evaluation strategy. For instance, more aggressive erasure
--   for lazy targets.
data EvaluationStrategy
LazyEvaluation :: EvaluationStrategy
EagerEvaluation :: EvaluationStrategy
data Compiled
Compiled :: TTerm -> Maybe [ArgUsage] -> Compiled
[cTreeless] :: Compiled -> TTerm

-- | <a>Nothing</a> if treeless usage analysis has not run yet.
[cArgUsage] :: Compiled -> Maybe [ArgUsage]
class Unreachable a

-- | Checks if the given expression is unreachable or not.
isUnreachable :: Unreachable a => a -> Bool

-- | Compiler-related primitives. This are NOT the same thing as primitives
--   in Agda's surface or internal syntax! Some of the primitives have a
--   suffix indicating which type of arguments they take, using the
--   following naming convention: Char | Type C | Character F | Float I |
--   Integer Q | QName S | String
data TPrim
PAdd :: TPrim
PAdd64 :: TPrim
PSub :: TPrim
PSub64 :: TPrim
PMul :: TPrim
PMul64 :: TPrim
PQuot :: TPrim
PQuot64 :: TPrim
PRem :: TPrim
PRem64 :: TPrim
PGeq :: TPrim
PLt :: TPrim
PLt64 :: TPrim
PEqI :: TPrim
PEq64 :: TPrim
PEqF :: TPrim
PEqS :: TPrim
PEqC :: TPrim
PEqQ :: TPrim
PIf :: TPrim
PSeq :: TPrim
PITo64 :: TPrim
P64ToI :: TPrim
data CaseInfo
CaseInfo :: Bool -> Erased -> CaseType -> CaseInfo
[caseLazy] :: CaseInfo -> Bool

-- | Is this a match on an erased argument?
[caseErased] :: CaseInfo -> Erased
[caseType] :: CaseInfo -> CaseType
data TAlt

-- | Matches on the given constructor. If the match succeeds, the pattern
--   variables are prepended to the current environment (pushes all
--   existing variables aArity steps further away)
TACon :: QName -> Int -> TTerm -> TAlt
[aCon] :: TAlt -> QName
[aArity] :: TAlt -> Int
[aBody] :: TAlt -> TTerm

-- | Binds no variables
--   
--   The guard must only use the variable that the case expression matches
--   on.
TAGuard :: TTerm -> TTerm -> TAlt
[aGuard] :: TAlt -> TTerm
[aBody] :: TAlt -> TTerm
TALit :: Literal -> TTerm -> TAlt
[aLit] :: TAlt -> Literal
[aBody] :: TAlt -> TTerm
data TError

-- | Code which is unreachable. E.g. absurd branches or missing case
--   defaults. Runtime behaviour of unreachable code is undefined, but
--   preferably the program will exit with an error message. The compiler
--   is free to assume that this code is unreachable and to remove it.
TUnreachable :: TError

-- | Code which could not be obtained because of a hole in the program.
--   This should throw a runtime error. The string gives some information
--   about the meta variable that got compiled.
TMeta :: String -> TError
data CaseType
CTData :: QName -> CaseType
CTNat :: CaseType
CTInt :: CaseType
CTChar :: CaseType
CTString :: CaseType
CTFloat :: CaseType
CTQName :: CaseType
pattern TPOp :: TPrim -> TTerm -> TTerm -> TTerm
pattern TPFn :: TPrim -> TTerm -> TTerm

-- | <tt>filterUsed used args</tt> drops those <tt>args</tt> which are
--   labelled <tt>ArgUnused</tt> in list <tt>used</tt>.
--   
--   Specification:
--   
--   <pre>
--   filterUsed used args = [ a | (a, ArgUsed) &lt;- zip args $ used ++ repeat ArgUsed ]
--   </pre>
--   
--   Examples:
--   
--   <pre>
--   filterUsed []                 == id
--   filterUsed (repeat ArgUsed)   == id
--   filterUsed (repeat ArgUnused) == const []
--   </pre>
filterUsed :: [ArgUsage] -> [a] -> [a]

-- | Introduces a new binding
mkLet :: TTerm -> TTerm -> TTerm
isPrimEq :: TPrim -> Bool

-- | Strip leading coercions and indicate whether there were some.
coerceView :: TTerm -> (Bool, TTerm)
mkTApp :: TTerm -> Args -> TTerm
tAppView :: TTerm -> (TTerm, [TTerm])

-- | Expose the format <tt>coerce f args</tt>.
--   
--   We fuse coercions, even if interleaving with applications. We assume
--   that coercion is powerful enough to satisfy <tt> coerce (coerce f a) b
--   = coerce f a b </tt>
coerceAppView :: TTerm -> ((Bool, TTerm), [TTerm])
tLetView :: TTerm -> ([TTerm], TTerm)
tLamView :: TTerm -> (Int, TTerm)
mkTLam :: Int -> TTerm -> TTerm
tInt :: Integer -> TTerm
intView :: TTerm -> Maybe Integer
word64View :: TTerm -> Maybe Word64
tPlusK :: Integer -> TTerm -> TTerm
tOp :: TPrim -> TTerm -> TTerm -> TTerm
tNegPlusK :: Integer -> TTerm -> TTerm
plusKView :: TTerm -> Maybe (Integer, TTerm)
negPlusKView :: TTerm -> Maybe (Integer, TTerm)
tUnreachable :: TTerm
tIfThenElse :: TTerm -> TTerm -> TTerm -> TTerm
instance GHC.Generics.Generic Agda.Syntax.Treeless.ArgUsage
instance GHC.Classes.Ord Agda.Syntax.Treeless.ArgUsage
instance GHC.Classes.Eq Agda.Syntax.Treeless.ArgUsage
instance GHC.Show.Show Agda.Syntax.Treeless.ArgUsage
instance GHC.Show.Show Agda.Syntax.Treeless.EvaluationStrategy
instance GHC.Classes.Eq Agda.Syntax.Treeless.EvaluationStrategy
instance GHC.Generics.Generic Agda.Syntax.Treeless.TPrim
instance GHC.Classes.Ord Agda.Syntax.Treeless.TPrim
instance GHC.Classes.Eq Agda.Syntax.Treeless.TPrim
instance GHC.Show.Show Agda.Syntax.Treeless.TPrim
instance GHC.Generics.Generic Agda.Syntax.Treeless.CaseType
instance GHC.Classes.Ord Agda.Syntax.Treeless.CaseType
instance GHC.Classes.Eq Agda.Syntax.Treeless.CaseType
instance GHC.Show.Show Agda.Syntax.Treeless.CaseType
instance GHC.Generics.Generic Agda.Syntax.Treeless.CaseInfo
instance GHC.Classes.Ord Agda.Syntax.Treeless.CaseInfo
instance GHC.Classes.Eq Agda.Syntax.Treeless.CaseInfo
instance GHC.Show.Show Agda.Syntax.Treeless.CaseInfo
instance GHC.Generics.Generic Agda.Syntax.Treeless.TError
instance GHC.Classes.Ord Agda.Syntax.Treeless.TError
instance GHC.Classes.Eq Agda.Syntax.Treeless.TError
instance GHC.Show.Show Agda.Syntax.Treeless.TError
instance GHC.Generics.Generic Agda.Syntax.Treeless.TAlt
instance GHC.Classes.Ord Agda.Syntax.Treeless.TAlt
instance GHC.Classes.Eq Agda.Syntax.Treeless.TAlt
instance GHC.Show.Show Agda.Syntax.Treeless.TAlt
instance GHC.Generics.Generic Agda.Syntax.Treeless.TTerm
instance GHC.Classes.Ord Agda.Syntax.Treeless.TTerm
instance GHC.Classes.Eq Agda.Syntax.Treeless.TTerm
instance GHC.Show.Show Agda.Syntax.Treeless.TTerm
instance GHC.Generics.Generic Agda.Syntax.Treeless.Compiled
instance GHC.Classes.Ord Agda.Syntax.Treeless.Compiled
instance GHC.Classes.Eq Agda.Syntax.Treeless.Compiled
instance GHC.Show.Show Agda.Syntax.Treeless.Compiled
instance Agda.Syntax.Treeless.Unreachable Agda.Syntax.Treeless.TAlt
instance Agda.Syntax.Treeless.Unreachable Agda.Syntax.Treeless.TTerm
instance Agda.Syntax.Position.KillRange Agda.Syntax.Treeless.Compiled
instance Control.DeepSeq.NFData Agda.Syntax.Treeless.Compiled
instance Control.DeepSeq.NFData Agda.Syntax.Treeless.TTerm
instance Control.DeepSeq.NFData Agda.Syntax.Treeless.TAlt
instance Control.DeepSeq.NFData Agda.Syntax.Treeless.TError
instance Control.DeepSeq.NFData Agda.Syntax.Treeless.CaseInfo
instance Control.DeepSeq.NFData Agda.Syntax.Treeless.CaseType
instance Control.DeepSeq.NFData Agda.Syntax.Treeless.TPrim
instance Control.DeepSeq.NFData Agda.Syntax.Treeless.ArgUsage


-- | Translates guard alternatives to if-then-else cascades.
--   
--   The builtin translation must be run before this transformation.
module Agda.Compiler.Treeless.GuardsToPrims
convertGuards :: TTerm -> TTerm

module Agda.Compiler.Treeless.AsPatterns

-- | We lose track of @-patterns in the internal syntax. This pass puts
--   them back.
recoverAsPatterns :: Monad m => TTerm -> m TTerm
instance GHC.Show.Show Agda.Compiler.Treeless.AsPatterns.AsPat

module Agda.Syntax.Parser.Tokens
data Token
TokKeyword :: Keyword -> Interval -> Token
TokId :: (Interval, String) -> Token
TokQId :: [(Interval, String)] -> Token
TokLiteral :: RLiteral -> Token
TokSymbol :: Symbol -> Interval -> Token

-- | Arbitrary string (not enclosed in double quotes), used in pragmas.
TokString :: (Interval, String) -> Token
TokTeX :: (Interval, String) -> Token
TokMarkup :: (Interval, String) -> Token
TokComment :: (Interval, String) -> Token
TokDummy :: Token
TokEOF :: Interval -> Token
data Keyword
KwLet :: Keyword
KwIn :: Keyword
KwWhere :: Keyword
KwData :: Keyword
KwCoData :: Keyword
KwDo :: Keyword
KwPostulate :: Keyword
KwAbstract :: Keyword
KwPrivate :: Keyword
KwInstance :: Keyword
KwInterleaved :: Keyword
KwMutual :: Keyword
KwOverlap :: Keyword
KwOpen :: Keyword
KwImport :: Keyword
KwModule :: Keyword
KwPrimitive :: Keyword
KwMacro :: Keyword
KwInfix :: Keyword
KwInfixL :: Keyword
KwInfixR :: Keyword
KwWith :: Keyword
KwRewrite :: Keyword
KwForall :: Keyword
KwRecord :: Keyword
KwConstructor :: Keyword
KwField :: Keyword
KwInductive :: Keyword
KwCoInductive :: Keyword
KwEta :: Keyword
KwNoEta :: Keyword
KwHiding :: Keyword
KwUsing :: Keyword
KwRenaming :: Keyword
KwTo :: Keyword
KwPublic :: Keyword
KwOpaque :: Keyword
KwUnfolding :: Keyword
KwOPTIONS :: Keyword
KwBUILTIN :: Keyword
KwLINE :: Keyword
KwFOREIGN :: Keyword
KwCOMPILE :: Keyword
KwIMPOSSIBLE :: Keyword
KwSTATIC :: Keyword
KwINJECTIVE :: Keyword
KwINJECTIVE_FOR_INFERENCE :: Keyword
KwINLINE :: Keyword
KwNOINLINE :: Keyword
KwETA :: Keyword
KwNO_TERMINATION_CHECK :: Keyword
KwTERMINATING :: Keyword
KwNON_TERMINATING :: Keyword
KwNOT_PROJECTION_LIKE :: Keyword
KwNON_COVERING :: Keyword
KwWARNING_ON_USAGE :: Keyword
KwWARNING_ON_IMPORT :: Keyword
KwMEASURE :: Keyword
KwDISPLAY :: Keyword
KwREWRITE :: Keyword
KwOVERLAPPABLE :: Keyword
KwOVERLAPPING :: Keyword
KwOVERLAPS :: Keyword
KwINCOHERENT :: Keyword
KwQuote :: Keyword
KwQuoteTerm :: Keyword
KwUnquote :: Keyword
KwUnquoteDecl :: Keyword
KwUnquoteDef :: Keyword
KwSyntax :: Keyword
KwPatternSyn :: Keyword
KwTactic :: Keyword
KwCATCHALL :: Keyword
KwVariable :: Keyword
KwNO_POSITIVITY_CHECK :: Keyword
KwPOLARITY :: Keyword
KwNO_UNIVERSE_CHECK :: Keyword

-- | Unconditional layout keywords.
--   
--   Some keywords introduce layout only in certain circumstances, these
--   are not included here.
layoutKeywords :: [Keyword]
data Symbol
SymDot :: Symbol
SymSemi :: Symbol
SymVirtualSemi :: Symbol
SymBar :: Symbol
SymColon :: Symbol
SymArrow :: Symbol
SymEqual :: Symbol
SymLambda :: Symbol
SymUnderscore :: Symbol
SymQuestionMark :: Symbol
SymAs :: Symbol
SymOpenParen :: Symbol
SymCloseParen :: Symbol
SymOpenIdiomBracket :: Symbol
SymCloseIdiomBracket :: Symbol
SymEmptyIdiomBracket :: Symbol
SymDoubleOpenBrace :: Symbol
SymDoubleCloseBrace :: Symbol
SymOpenBrace :: Symbol
SymCloseBrace :: Symbol
SymOpenVirtualBrace :: Symbol
SymCloseVirtualBrace :: Symbol
SymOpenPragma :: Symbol
SymClosePragma :: Symbol
SymEllipsis :: Symbol
SymDotDot :: Symbol

-- | A misplaced end-comment "-}".
SymEndComment :: Symbol
instance GHC.Show.Show Agda.Syntax.Parser.Tokens.Keyword
instance GHC.Classes.Eq Agda.Syntax.Parser.Tokens.Keyword
instance GHC.Show.Show Agda.Syntax.Parser.Tokens.Symbol
instance GHC.Classes.Eq Agda.Syntax.Parser.Tokens.Symbol
instance GHC.Show.Show Agda.Syntax.Parser.Tokens.Token
instance GHC.Classes.Eq Agda.Syntax.Parser.Tokens.Token
instance Agda.Syntax.Position.HasRange Agda.Syntax.Parser.Tokens.Token


-- | The concrete syntax is a raw representation of the program text
--   without any desugaring at all. This is what the parser produces. The
--   idea is that if we figure out how to keep the concrete syntax around,
--   it can be printed exactly as the user wrote it.
module Agda.Syntax.Concrete

-- | Concrete expressions. Should represent exactly what the user wrote.
data Expr

-- | ex: <tt>x</tt>
Ident :: QName -> Expr

-- | ex: <tt>1</tt> or <tt>"foo"</tt>
Lit :: Range -> Literal -> Expr

-- | ex: <tt>?</tt> or <tt>{! ... !}</tt>
QuestionMark :: Range -> Maybe Nat -> Expr

-- | ex: <tt>_</tt> or <tt>_A_5</tt>
Underscore :: Range -> Maybe String -> Expr

-- | before parsing operators
RawApp :: Range -> List2 Expr -> Expr

-- | ex: <tt>e e</tt>, <tt>e {e}</tt>, or <tt>e {x = e}</tt>
App :: Range -> Expr -> NamedArg Expr -> Expr

-- | ex: <tt>e + e</tt> The <a>QName</a> is possibly ambiguous, but it must
--   correspond to one of the names in the set.
OpApp :: Range -> QName -> Set Name -> OpAppArgs -> Expr

-- | ex: <tt>e | e1 | .. | en</tt>
WithApp :: Range -> Expr -> [Expr] -> Expr

-- | ex: <tt>{e}</tt> or <tt>{x=e}</tt>
HiddenArg :: Range -> Named_ Expr -> Expr

-- | ex: <tt>{{e}}</tt> or <tt>{{x=e}}</tt>
InstanceArg :: Range -> Named_ Expr -> Expr

-- | ex: <tt>\x {y} -&gt; e</tt> or <tt>\(x:A){y:B} -&gt; e</tt>
Lam :: Range -> List1 LamBinding -> Expr -> Expr

-- | ex: <tt>\ ()</tt>
AbsurdLam :: Range -> Hiding -> Expr

-- | ex: <tt>\ { p11 .. p1a -&gt; e1 ; .. ; pn1 .. pnz -&gt; en }</tt>
ExtendedLam :: Range -> Erased -> List1 LamClause -> Expr

-- | ex: <tt>e -&gt; e</tt> or <tt>.e -&gt; e</tt> (NYI: <tt>{e} -&gt;
--   e</tt>)
Fun :: Range -> Arg Expr -> Expr -> Expr

-- | ex: <tt>(xs:e) -&gt; e</tt> or <tt>{xs:e} -&gt; e</tt>
Pi :: Telescope1 -> Expr -> Expr

-- | ex: <tt>record {x = a; y = b}</tt>, or <tt>record { x = a; M1; M2
--   }</tt>
Rec :: Range -> RecordAssignments -> Expr

-- | ex: <tt>record e {x = a; y = b}</tt>
RecUpdate :: Range -> Expr -> [FieldAssignment] -> Expr

-- | ex: <tt>let Ds in e</tt>, missing body when parsing do-notation let
Let :: Range -> List1 Declaration -> Maybe Expr -> Expr

-- | ex: <tt>(e)</tt>
Paren :: Range -> Expr -> Expr

-- | ex: <tt>(| e1 | e2 | .. | en |)</tt> or <tt>(|)</tt>
IdiomBrackets :: Range -> [Expr] -> Expr

-- | ex: <tt>do x &lt;- m1; m2</tt>
DoBlock :: Range -> List1 DoStmt -> Expr

-- | ex: <tt>()</tt> or <tt>{}</tt>, only in patterns
Absurd :: Range -> Expr

-- | ex: <tt>x@p</tt>, only in patterns
As :: Range -> Name -> Expr -> Expr

-- | ex: <tt>.p</tt>, only in patterns
Dot :: Range -> Expr -> Expr

-- | ex: <tt>..A</tt>, used for parsing <tt>..A -&gt; B</tt>
DoubleDot :: Range -> Expr -> Expr

-- | ex: <tt>quote</tt>, should be applied to a name
Quote :: Range -> Expr

-- | ex: <tt>quoteTerm</tt>, should be applied to a term
QuoteTerm :: Range -> Expr

-- | ex: <tt>@(tactic t)</tt>, used to declare tactic arguments
Tactic :: Range -> Expr -> Expr

-- | ex: <tt>unquote</tt>, should be applied to a term of type
--   <tt>Term</tt>
Unquote :: Range -> Expr

-- | to print irrelevant things
DontCare :: Expr -> Expr

-- | ex: <tt>a = b</tt>, used internally in the parser
Equal :: Range -> Expr -> Expr -> Expr

-- | <tt>...</tt>, used internally to parse patterns.
Ellipsis :: Range -> Expr

-- | An identifier coming from abstract syntax, for which we know a precise
--   syntactic highlighting class (used in printing).
KnownIdent :: NameKind -> QName -> Expr

-- | An operator application coming from abstract syntax, for which we know
--   a precise syntactic highlighting class (used in printing).
KnownOpApp :: NameKind -> Range -> QName -> Set Name -> OpAppArgs -> Expr
Generalized :: Expr -> Expr
data OpApp e

-- | An abstraction inside a special syntax declaration (see Issue 358 why
--   we introduce this).
SyntaxBindingLambda :: Range -> List1 LamBinding -> e -> OpApp e
Ordinary :: e -> OpApp e
fromOrdinary :: e -> OpApp e -> e
type OpAppArgs = OpAppArgs' Expr
type OpAppArgs' e = [NamedArg (MaybePlaceholder (OpApp e))]

-- | The <a>Expr</a> is not an application.
data AppView
AppView :: Expr -> [NamedArg Expr] -> AppView
appView :: Expr -> AppView
unAppView :: AppView -> Expr
rawApp :: List1 Expr -> Expr
rawAppP :: List1 Pattern -> Pattern
isSingleIdentifierP :: Pattern -> Maybe Name
removeParenP :: Pattern -> Pattern

-- | Turn an expression into a pattern. Fails if the expression is not a
--   valid pattern.
isPattern :: Expr -> Maybe Pattern
isAbsurdP :: Pattern -> Maybe (Range, Hiding)
isBinderP :: Pattern -> Maybe Binder

-- | Observe the hiding status of an expression
observeHiding :: Expr -> WithHiding Expr

-- | Observe the relevance status of an expression
observeRelevance :: Expr -> (Relevance, Expr)

-- | Observe various modifiers applied to an expression
observeModifiers :: Expr -> Arg Expr

-- | Turn an expression into a pattern, turning non-pattern subexpressions
--   into <a>WildP</a>.
exprToPatternWithHoles :: Expr -> Pattern
returnExpr :: Expr -> Maybe Expr

-- | A Binder <tt>x@p</tt>, the pattern is optional
data Binder' a
Binder :: Maybe Pattern -> a -> Binder' a
[binderPattern] :: Binder' a -> Maybe Pattern
[binderName] :: Binder' a -> a
type Binder = Binder' BoundName
mkBinder_ :: Name -> Binder
mkBinder :: a -> Binder' a

-- | A lambda binding is either domain free or typed.
type LamBinding = LamBinding' TypedBinding
data LamBinding' a

-- | . <tt>x</tt> or <tt>{x}</tt> or <tt>.x</tt> or <tt>.{x}</tt> or
--   <tt>{.x}</tt> or <tt>x@p</tt> or <tt>(p)</tt>
DomainFree :: NamedArg Binder -> LamBinding' a

-- | . <tt>(xs : e)</tt> or <tt>{xs : e}</tt>
DomainFull :: a -> LamBinding' a

-- | Drop type annotations and lets from bindings.
dropTypeAndModality :: LamBinding -> [LamBinding]

-- | A typed binding.
type TypedBinding = TypedBinding' Expr
data TypedBinding' e

-- | Binding <tt>(x1@p1 ... xn@pn : A)</tt>.
TBind :: Range -> List1 (NamedArg Binder) -> e -> TypedBinding' e

-- | Let binding <tt>(let Ds)</tt> or <tt>(open M args)</tt>.
TLet :: Range -> List1 Declaration -> TypedBinding' e
type RecordAssignment = Either FieldAssignment ModuleAssignment
type RecordAssignments = [RecordAssignment]
type FieldAssignment = FieldAssignment' Expr
data FieldAssignment' a
FieldAssignment :: Name -> a -> FieldAssignment' a
[_nameFieldA] :: FieldAssignment' a -> Name
[_exprFieldA] :: FieldAssignment' a -> a
nameFieldA :: Lens' (FieldAssignment' a) Name
exprFieldA :: Lens' (FieldAssignment' a) a
data ModuleAssignment
ModuleAssignment :: QName -> [Expr] -> ImportDirective -> ModuleAssignment
[_qnameModA] :: ModuleAssignment -> QName
[_exprModA] :: ModuleAssignment -> [Expr]
[_importDirModA] :: ModuleAssignment -> ImportDirective
data BoundName
BName :: Name -> Fixity' -> TacticAttribute -> Bool -> BoundName
[boundName] :: BoundName -> Name
[bnameFixity] :: BoundName -> Fixity'

-- | From <tt>@tactic</tt> attribute.
[bnameTactic] :: BoundName -> TacticAttribute

-- | The <tt>@finite</tt> cannot be parsed, it comes from the builtin
--   <tt>Partial</tt> only.
[bnameIsFinite] :: BoundName -> Bool
mkBoundName_ :: Name -> BoundName
mkBoundName :: Name -> Fixity' -> BoundName
type TacticAttribute = TacticAttribute' Expr
newtype TacticAttribute' a
TacticAttribute :: Maybe (Ranged a) -> TacticAttribute' a
[theTacticAttribute] :: TacticAttribute' a -> Maybe (Ranged a)
type Telescope = [TypedBinding]

-- | A telescope is a sequence of typed bindings. Bound variables are in
--   scope in later types.
type Telescope1 = List1 TypedBinding

-- | We can try to get a <tt>Telescope</tt> from a <tt>[LamBinding]</tt>.
--   If we have a type annotation already, we're happy. Otherwise we
--   manufacture a binder with an underscore for the type.
lamBindingsToTelescope :: Range -> [LamBinding] -> Telescope

-- | Smart constructor for <tt>Pi</tt>: check whether the
--   <tt>Telescope</tt> is empty
makePi :: Telescope -> Expr -> Expr

-- | Smart constructor for <tt>Lam</tt>: check for non-zero bindings.
mkLam :: Range -> [LamBinding] -> Expr -> Expr

-- | Smart constructor for <tt>Let</tt>: check for non-zero let bindings.
mkLet :: Range -> [Declaration] -> Expr -> Expr

-- | Smart constructor for <tt>TLet</tt>: check for non-zero let bindings.
mkTLet :: Range -> [Declaration] -> Maybe (TypedBinding' e)

-- | The representation type of a declaration. The comments indicate which
--   type in the intended family the constructor targets.
data Declaration

-- | Axioms and functions can be irrelevant. (Hiding should be NotHidden)
TypeSig :: ArgInfo -> TacticAttribute -> Name -> Expr -> Declaration
FieldSig :: IsInstance -> TacticAttribute -> Name -> Arg Expr -> Declaration

-- | Variables to be generalized, can be hidden and/or irrelevant.
Generalize :: KwRange -> [TypeSignature] -> Declaration
Field :: KwRange -> [FieldSignature] -> Declaration
FunClause :: LHS -> RHS -> WhereClause -> Bool -> Declaration

-- | lone data signature in mutual block
DataSig :: Range -> Erased -> Name -> [LamBinding] -> Expr -> Declaration
Data :: Range -> Erased -> Name -> [LamBinding] -> Expr -> [TypeSignatureOrInstanceBlock] -> Declaration
DataDef :: Range -> Name -> [LamBinding] -> [TypeSignatureOrInstanceBlock] -> Declaration

-- | lone record signature in mutual block
RecordSig :: Range -> Erased -> Name -> [LamBinding] -> Expr -> Declaration
RecordDef :: Range -> Name -> [RecordDirective] -> [LamBinding] -> [Declaration] -> Declaration
Record :: Range -> Erased -> Name -> [RecordDirective] -> [LamBinding] -> Expr -> [Declaration] -> Declaration
Infix :: Fixity -> List1 Name -> Declaration

-- | notation declaration for a name
Syntax :: Name -> Notation -> Declaration
PatternSyn :: Range -> Name -> [WithHiding Name] -> Pattern -> Declaration
Mutual :: KwRange -> [Declaration] -> Declaration
InterleavedMutual :: KwRange -> [Declaration] -> Declaration
Abstract :: KwRange -> [Declaration] -> Declaration

-- | In <a>Agda.Syntax.Concrete.Definitions</a> we generate private blocks
--   temporarily, which should be treated different that user-declared
--   private blocks. Thus the <a>Origin</a>.
Private :: KwRange -> Origin -> [Declaration] -> Declaration

-- | The <a>KwRange</a> here only refers to the range of the
--   <tt>instance</tt> keyword. The range of the whole block <tt>InstanceB
--   r ds</tt> is <tt>fuseRange r ds</tt>.
InstanceB :: KwRange -> [Declaration] -> Declaration
LoneConstructor :: KwRange -> [Declaration] -> Declaration
Macro :: KwRange -> [Declaration] -> Declaration
Postulate :: KwRange -> [TypeSignatureOrInstanceBlock] -> Declaration
Primitive :: KwRange -> [TypeSignature] -> Declaration
Open :: Range -> QName -> ImportDirective -> Declaration
Import :: Range -> QName -> Maybe AsName -> !OpenShortHand -> ImportDirective -> Declaration
ModuleMacro :: Range -> Erased -> Name -> ModuleApplication -> !OpenShortHand -> ImportDirective -> Declaration
Module :: Range -> Erased -> QName -> Telescope -> [Declaration] -> Declaration

-- | <pre>
--   unquoteDecl xs = e
--   </pre>
UnquoteDecl :: Range -> [Name] -> Expr -> Declaration

-- | <pre>
--   unquoteDef xs = e
--   </pre>
UnquoteDef :: Range -> [Name] -> Expr -> Declaration

-- | <pre>
--   unquoteDecl data d constructor xs = e
--   </pre>
UnquoteData :: Range -> Name -> [Name] -> Expr -> Declaration
Pragma :: Pragma -> Declaration

-- | <pre>
--   opaque ...
--   </pre>
Opaque :: KwRange -> [Declaration] -> Declaration

-- | <pre>
--   unfolding ...
--   </pre>
Unfolding :: KwRange -> [QName] -> Declaration

-- | Return <a>Declaration</a> if <a>Declaration</a> is <a>Declaration</a>.
isPragma :: CMaybe Pragma m => Declaration -> m

-- | Isolated record directives parsed as Declarations
data RecordDirective

-- | Range of keyword <tt>[co]inductive</tt>.
Induction :: Ranged Induction -> RecordDirective
Constructor :: Name -> IsInstance -> RecordDirective

-- | Range of <tt>[no-]eta-equality</tt> keyword.
Eta :: Ranged HasEta0 -> RecordDirective

-- | If declaration <tt>pattern</tt> is present, give its range.
PatternOrCopattern :: Range -> RecordDirective
type RecordDirectives = RecordDirectives' (Name, IsInstance)
data ModuleApplication

-- | <pre>
--   tel. M args
--   </pre>
SectionApp :: Range -> Telescope -> Expr -> ModuleApplication

-- | <pre>
--   M {{...}}
--   </pre>
RecordModuleInstance :: Range -> QName -> ModuleApplication

-- | Just type signatures.
type TypeSignature = Declaration

-- | Just type signatures or instance blocks.
type TypeSignatureOrInstanceBlock = Declaration

-- | The things you are allowed to say when you shuffle names between name
--   spaces (i.e. in <tt>import</tt>, <tt>namespace</tt>, or <tt>open</tt>
--   declarations).
type ImportDirective = ImportDirective' Name Name
type Using = Using' Name Name

-- | An imported name can be a module or a defined name.
type ImportedName = ImportedName' Name Name
type Renaming = Renaming' Name Name
type RenamingDirective = RenamingDirective' Name Name
type HidingDirective = HidingDirective' Name Name

-- | The content of the <tt>as</tt>-clause of the import statement.
data AsName' a
AsName :: a -> Range -> AsName' a

-- | The "as" name.
[asName] :: AsName' a -> a

-- | The range of the "as" keyword. Retained for highlighting purposes.
[asRange] :: AsName' a -> Range

-- | From the parser, we get an expression for the <tt>as</tt>-<a>Name</a>,
--   which we have to parse into a <a>Name</a>.
type AsName = AsName' (Either Expr Name)
data OpenShortHand
DoOpen :: OpenShortHand
DontOpen :: OpenShortHand
type RewriteEqn = RewriteEqn' () Name Pattern Expr
type WithExpr = Named Name (Arg Expr)

-- | Left hand sides can be written in infix style. For example:
--   
--   <pre>
--   n + suc m = suc (n + m)
--   (f ∘ g) x = f (g x)
--   </pre>
--   
--   We use fixity information to see which name is actually defined.
data LHS

-- | Original pattern (including with-patterns), rewrite equations and
--   with-expressions.
LHS :: Pattern -> [RewriteEqn] -> [WithExpr] -> LHS

-- | e.g. <tt>f ps | wps</tt>
[lhsOriginalPattern] :: LHS -> Pattern

-- | <tt>(rewrite e | with p &lt;- e in eq)</tt> (many)
[lhsRewriteEqn] :: LHS -> [RewriteEqn]

-- | <tt>with e1 in eq | {e2} | ...</tt> (many)
[lhsWithExpr] :: LHS -> [WithExpr]

-- | Concrete patterns. No literals in patterns at the moment.
data Pattern

-- | <tt>c</tt> or <tt>x</tt>
--   
--   If the boolean is <a>False</a>, then the <a>QName</a> must not refer
--   to a constructor or a pattern synonym. The value <a>False</a> is used
--   when a hidden argument pun is expanded.
IdentP :: Bool -> QName -> Pattern

-- | <pre>
--   quote
--   </pre>
QuoteP :: Range -> Pattern

-- | <tt>p p'</tt> or <tt>p {x = p'}</tt>
AppP :: Pattern -> NamedArg Pattern -> Pattern

-- | <tt>p1..pn</tt> before parsing operators
RawAppP :: Range -> List2 Pattern -> Pattern

-- | eg: <tt>p =&gt; p'</tt> for operator <tt>_=&gt;_</tt> The <a>QName</a>
--   is possibly ambiguous, but it must correspond to one of the names in
--   the set.
OpAppP :: Range -> QName -> Set Name -> [NamedArg Pattern] -> Pattern

-- | <tt>{p}</tt> or <tt>{x = p}</tt>
HiddenP :: Range -> Named_ Pattern -> Pattern

-- | <tt>{{p}}</tt> or <tt>{{x = p}}</tt>
InstanceP :: Range -> Named_ Pattern -> Pattern

-- | <pre>
--   (p)
--   </pre>
ParenP :: Range -> Pattern -> Pattern

-- | <pre>
--   _
--   </pre>
WildP :: Range -> Pattern

-- | <pre>
--   ()
--   </pre>
AbsurdP :: Range -> Pattern

-- | <tt>x@p</tt> unused
AsP :: Range -> Name -> Pattern -> Pattern

-- | <pre>
--   .e
--   </pre>
DotP :: Range -> Expr -> Pattern

-- | <tt>0</tt>, <tt>1</tt>, etc.
LitP :: Range -> Literal -> Pattern

-- | <pre>
--   record {x = p; y = q}
--   </pre>
RecP :: Range -> [FieldAssignment' Pattern] -> Pattern

-- | <tt>i = i1</tt> i.e. cubical face lattice generator
EqualP :: Range -> [(Expr, Expr)] -> Pattern

-- | <tt>...</tt>, only as left-most pattern. Second arg is
--   <tt>Nothing</tt> before expansion, and <tt>Just p</tt> after expanding
--   ellipsis to <tt>p</tt>.
EllipsisP :: Range -> Maybe Pattern -> Pattern

-- | <tt>| p</tt>, for with-patterns.
WithP :: Range -> Pattern -> Pattern

-- | Processed (operator-parsed) intermediate form of the core <tt>f
--   ps</tt> of <a>LHS</a>. Corresponds to <a>lhsOriginalPattern</a>.
data LHSCore
LHSHead :: QName -> [NamedArg Pattern] -> LHSCore

-- | <pre>
--   f
--   </pre>
[lhsDefName] :: LHSCore -> QName

-- | <pre>
--   ps
--   </pre>
[lhsPats] :: LHSCore -> [NamedArg Pattern]
LHSProj :: QName -> [NamedArg Pattern] -> NamedArg LHSCore -> [NamedArg Pattern] -> LHSCore

-- | Record projection.
[lhsDestructor] :: LHSCore -> QName

-- | Patterns for record indices (currently none).
[lhsPatsLeft] :: LHSCore -> [NamedArg Pattern]

-- | Main argument.
[lhsFocus] :: LHSCore -> NamedArg LHSCore

-- | <pre>
--   ps
--   </pre>
[lhsPats] :: LHSCore -> [NamedArg Pattern]
LHSWith :: LHSCore -> [Pattern] -> [NamedArg Pattern] -> LHSCore
[lhsHead] :: LHSCore -> LHSCore

-- | Non-empty; at least one <tt>(| p)</tt>.
[lhsWithPatterns] :: LHSCore -> [Pattern]

-- | <pre>
--   ps
--   </pre>
[lhsPats] :: LHSCore -> [NamedArg Pattern]
LHSEllipsis :: Range -> LHSCore -> LHSCore
[lhsEllipsisRange] :: LHSCore -> Range

-- | Pattern that was expanded from an ellipsis <tt>...</tt>.
[lhsEllipsisPat] :: LHSCore -> LHSCore
data LamClause
LamClause :: [Pattern] -> RHS -> Bool -> LamClause

-- | Possibly empty sequence.
[lamLHS] :: LamClause -> [Pattern]
[lamRHS] :: LamClause -> RHS
[lamCatchAll] :: LamClause -> Bool
type RHS = RHS' Expr
data RHS' e

-- | No right hand side because of absurd match.
AbsurdRHS :: RHS' e
RHS :: e -> RHS' e

-- | <tt>where</tt> block following a clause.
type WhereClause = WhereClause' [Declaration]
data WhereClause' decls

-- | No <tt>where</tt> clauses.
NoWhere :: WhereClause' decls

-- | Ordinary <tt>where</tt>. <a>Range'</a> of the <tt>where</tt> keyword.
--   List of declarations can be empty.
AnyWhere :: Range -> decls -> WhereClause' decls

-- | Named where: <tt>module M where ds</tt>. <a>Range'</a> of the keywords
--   <tt>module</tt> and <tt>where</tt>. The <a>Access</a> flag applies to
--   the <a>Name</a> (not the module contents!) and is propagated from the
--   parent function. List of declarations can be empty.
SomeWhere :: Range -> Erased -> Name -> Access -> decls -> WhereClause' decls

-- | An expression followed by a where clause. Currently only used to give
--   better a better error message in interaction.
data ExprWhere
ExprWhere :: Expr -> WhereClause -> ExprWhere
data DoStmt

-- | <pre>
--   p ← e where cs
--   </pre>
DoBind :: Range -> Pattern -> Expr -> [LamClause] -> DoStmt
DoThen :: Expr -> DoStmt
DoLet :: Range -> List1 Declaration -> DoStmt
data Pragma
OptionsPragma :: Range -> [String] -> Pragma
BuiltinPragma :: Range -> RString -> QName -> Pragma

-- | Second Range is for REWRITE keyword.
RewritePragma :: Range -> Range -> [QName] -> Pragma

-- | first string is backend name
ForeignPragma :: Range -> RString -> String -> Pragma

-- | first string is backend name
CompilePragma :: Range -> RString -> QName -> String -> Pragma
StaticPragma :: Range -> QName -> Pragma

-- | INLINE or NOINLINE
InlinePragma :: Range -> Bool -> QName -> Pragma

-- | Throws an internal error in the scope checker. The <a>String</a>s are
--   words to be displayed with the error.
ImpossiblePragma :: Range -> [String] -> Pragma

-- | For coinductive records, use pragma instead of regular
--   <tt>eta-equality</tt> definition (as it is might make Agda loop).
EtaPragma :: Range -> QName -> Pragma

-- | Applies to the named function
WarningOnUsage :: Range -> QName -> Text -> Pragma

-- | Applies to the current module
WarningOnImport :: Range -> Text -> Pragma

-- | Mark a definition as injective for the pattern matching unifier.
InjectivePragma :: Range -> QName -> Pragma

-- | Mark a definition as injective for the conversion checker
InjectiveForInferencePragma :: Range -> QName -> Pragma

-- | Display lhs as rhs (modifies the printer).
DisplayPragma :: Range -> Pattern -> Expr -> Pragma

-- | Applies to the following function clause.
CatchallPragma :: Range -> Pragma

-- | Applies to the following function (and all that are mutually recursive
--   with it) or to the functions in the following mutual block.
TerminationCheckPragma :: Range -> TerminationCheck Name -> Pragma

-- | Applies to the following function (and all that are mutually recursive
--   with it) or to the functions in the following mutual block.
NoCoverageCheckPragma :: Range -> Pragma

-- | Applies to the following data/record type or mutual block.
NoPositivityCheckPragma :: Range -> Pragma
PolarityPragma :: Range -> Name -> [Occurrence] -> Pragma

-- | Applies to the following data/record type.
NoUniverseCheckPragma :: Range -> Pragma

-- | Applies to the stated function
NotProjectionLikePragma :: Range -> QName -> Pragma

-- | Applies to the given name(s), which must be instance names (checked by
--   the type checker).
OverlapPragma :: Range -> [QName] -> OverlapMode -> Pragma

-- | Modules: Top-level pragmas plus other top-level declarations.
data Module
Mod :: [Pragma] -> [Declaration] -> Module
[modPragmas] :: Module -> [Pragma]
[modDecls] :: Module -> [Declaration]

-- | Decorating something with <tt>Fixity'</tt>.
data ThingWithFixity x
ThingWithFixity :: x -> Fixity' -> ThingWithFixity x
type HoleContent = HoleContent' () Name Pattern Expr

-- | Extended content of an interaction hole.
data HoleContent' qn nm p e

-- | <pre>
--   e
--   </pre>
HoleContentExpr :: e -> HoleContent' qn nm p e

-- | <pre>
--   (rewrite | invert) e0 | ... | en
--   </pre>
HoleContentRewrite :: [RewriteEqn' qn nm p e] -> HoleContent' qn nm p e

-- | Splits off allowed (= import) declarations before the first
--   non-allowed declaration. After successful parsing, the first
--   non-allowed declaration should be a module declaration.
spanAllowedBeforeModule :: [Declaration] -> ([Declaration], [Declaration])
ungatherRecordDirectives :: RecordDirectives -> [RecordDirective]
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Concrete.FieldAssignment' a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Concrete.FieldAssignment' a)
instance Data.Traversable.Traversable Agda.Syntax.Concrete.FieldAssignment'
instance Data.Foldable.Foldable Agda.Syntax.Concrete.FieldAssignment'
instance GHC.Base.Functor Agda.Syntax.Concrete.FieldAssignment'
instance Agda.Syntax.Position.KillRange (Agda.Syntax.Concrete.TacticAttribute' a)
instance Data.Traversable.Traversable Agda.Syntax.Concrete.TacticAttribute'
instance Data.Foldable.Foldable Agda.Syntax.Concrete.TacticAttribute'
instance GHC.Base.Functor Agda.Syntax.Concrete.TacticAttribute'
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Concrete.TacticAttribute' a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Concrete.TacticAttribute' a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Concrete.TacticAttribute' a)
instance GHC.Classes.Eq e => GHC.Classes.Eq (Agda.Syntax.Concrete.RHS' e)
instance Data.Traversable.Traversable Agda.Syntax.Concrete.RHS'
instance Data.Foldable.Foldable Agda.Syntax.Concrete.RHS'
instance GHC.Base.Functor Agda.Syntax.Concrete.RHS'
instance Data.Traversable.Traversable Agda.Syntax.Concrete.WhereClause'
instance Data.Foldable.Foldable Agda.Syntax.Concrete.WhereClause'
instance GHC.Base.Functor Agda.Syntax.Concrete.WhereClause'
instance GHC.Classes.Eq decls => GHC.Classes.Eq (Agda.Syntax.Concrete.WhereClause' decls)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Concrete.AsName' a)
instance Data.Traversable.Traversable Agda.Syntax.Concrete.AsName'
instance Data.Foldable.Foldable Agda.Syntax.Concrete.AsName'
instance GHC.Base.Functor Agda.Syntax.Concrete.AsName'
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Concrete.AsName' a)
instance GHC.Show.Show Agda.Syntax.Concrete.RecordDirective
instance GHC.Classes.Eq Agda.Syntax.Concrete.RecordDirective
instance GHC.Generics.Generic Agda.Syntax.Concrete.OpenShortHand
instance GHC.Show.Show Agda.Syntax.Concrete.OpenShortHand
instance GHC.Classes.Eq Agda.Syntax.Concrete.OpenShortHand
instance GHC.Classes.Eq Agda.Syntax.Concrete.ModuleAssignment
instance GHC.Classes.Eq e => GHC.Classes.Eq (Agda.Syntax.Concrete.OpApp e)
instance Data.Traversable.Traversable Agda.Syntax.Concrete.OpApp
instance Data.Foldable.Foldable Agda.Syntax.Concrete.OpApp
instance GHC.Base.Functor Agda.Syntax.Concrete.OpApp
instance GHC.Classes.Eq Agda.Syntax.Concrete.DoStmt
instance GHC.Classes.Eq Agda.Syntax.Concrete.LamClause
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Concrete.LamBinding' a)
instance Data.Traversable.Traversable Agda.Syntax.Concrete.LamBinding'
instance Data.Foldable.Foldable Agda.Syntax.Concrete.LamBinding'
instance GHC.Base.Functor Agda.Syntax.Concrete.LamBinding'
instance GHC.Classes.Eq Agda.Syntax.Concrete.LHS
instance Data.Traversable.Traversable Agda.Syntax.Concrete.Binder'
instance Data.Foldable.Foldable Agda.Syntax.Concrete.Binder'
instance GHC.Base.Functor Agda.Syntax.Concrete.Binder'
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Concrete.Binder' a)
instance GHC.Classes.Eq Agda.Syntax.Concrete.BoundName
instance GHC.Classes.Eq e => GHC.Classes.Eq (Agda.Syntax.Concrete.TypedBinding' e)
instance Data.Traversable.Traversable Agda.Syntax.Concrete.TypedBinding'
instance Data.Foldable.Foldable Agda.Syntax.Concrete.TypedBinding'
instance GHC.Base.Functor Agda.Syntax.Concrete.TypedBinding'
instance GHC.Classes.Eq Agda.Syntax.Concrete.ModuleApplication
instance GHC.Classes.Eq Agda.Syntax.Concrete.Declaration
instance GHC.Classes.Eq Agda.Syntax.Concrete.Expr
instance GHC.Classes.Eq Agda.Syntax.Concrete.Pattern
instance GHC.Classes.Eq Agda.Syntax.Concrete.Pragma
instance GHC.Classes.Eq Agda.Syntax.Concrete.LHSCore
instance Data.Traversable.Traversable (Agda.Syntax.Concrete.HoleContent' qn nm p)
instance Data.Foldable.Foldable (Agda.Syntax.Concrete.HoleContent' qn nm p)
instance GHC.Base.Functor (Agda.Syntax.Concrete.HoleContent' qn nm p)
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.LHSCore
instance Agda.Syntax.Common.LensHiding Agda.Syntax.Concrete.LamBinding
instance Agda.Syntax.Common.LensHiding Agda.Syntax.Concrete.TypedBinding
instance Agda.Syntax.Common.LensRelevance Agda.Syntax.Concrete.TypedBinding
instance Agda.Syntax.Position.HasRange e => Agda.Syntax.Position.HasRange (Agda.Syntax.Concrete.OpApp e)
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.Expr
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.Binder
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.TypedBinding
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.LamBinding
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.BoundName
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.WhereClause
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.ModuleApplication
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.ModuleAssignment
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.Declaration
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.LHS
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.RHS
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.LamClause
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.DoStmt
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.Pragma
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.AsName
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.Pattern
instance Agda.Syntax.Position.SetRange Agda.Syntax.Concrete.Pattern
instance Agda.Syntax.Position.SetRange Agda.Syntax.Concrete.TypedBinding
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.ModuleAssignment
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.AsName
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.Binder
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.BoundName
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.Declaration
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.Expr
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.LamBinding
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.LHS
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.LamClause
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.DoStmt
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.ModuleApplication
instance Agda.Syntax.Position.KillRange e => Agda.Syntax.Position.KillRange (Agda.Syntax.Concrete.OpApp e)
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.Pattern
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.Pragma
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.RHS
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.TypedBinding
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.WhereClause
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.Expr
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.Pattern
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.Declaration
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.Pragma
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.AsName
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Concrete.TypedBinding' a)
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.ModuleApplication
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Concrete.OpApp a)
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.LHS
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.ModuleAssignment
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.LamClause
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Concrete.LamBinding' a)
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.Binder
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.BoundName
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.DoStmt
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.OpenShortHand
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.RecordDirective
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.RecordDirective
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.RecordDirective
instance Agda.Utils.Null.Null (Agda.Syntax.Concrete.WhereClause' a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Concrete.WhereClause' a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Concrete.RHS' a)
instance Agda.Utils.Null.Null (Agda.Syntax.Concrete.TacticAttribute' a)
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange (Agda.Syntax.Concrete.FieldAssignment' a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Syntax.Concrete.FieldAssignment' a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Concrete.FieldAssignment' a)

module Agda.Syntax.TopLevelModuleName

-- | Top-level module names (with constant-time comparisons).
type TopLevelModuleName = TopLevelModuleName' Range

-- | Raw top-level module names (with linear-time comparisons).
data RawTopLevelModuleName
RawTopLevelModuleName :: Range -> TopLevelModuleNameParts -> RawTopLevelModuleName
[rawModuleNameRange] :: RawTopLevelModuleName -> Range
[rawModuleNameParts] :: RawTopLevelModuleName -> TopLevelModuleNameParts

-- | Finds the current project's "root" directory, given a project file and
--   the corresponding top-level module name.
--   
--   Example: If the module "A.B.C" is located in the file
--   "<i>foo</i>A<i>B</i>C.agda", then the root is "<i>foo</i>".
--   
--   Precondition: The module name must be well-formed.
projectRoot :: AbsolutePath -> TopLevelModuleName -> AbsolutePath

-- | Turns a raw top-level module name into a string.
rawTopLevelModuleNameToString :: RawTopLevelModuleName -> String

-- | Hashes a raw top-level module name.
hashRawTopLevelModuleName :: RawTopLevelModuleName -> ModuleNameHash

-- | Turns a qualified name into a <a>RawTopLevelModuleName</a>. The
--   qualified name is assumed to represent a top-level module name.
rawTopLevelModuleNameForQName :: QName -> RawTopLevelModuleName

-- | Computes the <a>RawTopLevelModuleName</a> corresponding to the given
--   module name, which is assumed to represent a top-level module name.
--   
--   Precondition: The module name must be well-formed.
rawTopLevelModuleNameForModuleName :: ModuleName -> RawTopLevelModuleName

-- | Computes the top-level module name.
--   
--   Precondition: The <a>Declaration</a> has to be well-formed. This means
--   that there are only allowed declarations before the first module
--   declaration, typically import declarations. See
--   <tt>spanAllowedBeforeModule</tt>.
rawTopLevelModuleNameForModule :: Module -> RawTopLevelModuleName

-- | Converts a top-level module name to a raw top-level module name.
rawTopLevelModuleName :: TopLevelModuleName -> RawTopLevelModuleName

-- | A lens focusing on the <a>moduleNameParts</a>.
lensTopLevelModuleNameParts :: Lens' TopLevelModuleName TopLevelModuleNameParts

-- | Converts a raw top-level module name and a hash to a top-level module
--   name.
--   
--   This function does not ensure that there are no hash collisions, that
--   is taken care of by <a>topLevelModuleName</a>.
unsafeTopLevelModuleName :: RawTopLevelModuleName -> ModuleNameHash -> TopLevelModuleName

-- | A corresponding <a>QName</a>. The range of each <tt>Name</tt> part is
--   the whole range of the <a>TopLevelModuleName</a>.
topLevelModuleNameToQName :: TopLevelModuleName -> QName

-- | Turns a top-level module name into a file name with the given suffix.
moduleNameToFileName :: TopLevelModuleName -> String -> FilePath
instance GHC.Generics.Generic Agda.Syntax.TopLevelModuleName.RawTopLevelModuleName
instance GHC.Show.Show Agda.Syntax.TopLevelModuleName.RawTopLevelModuleName
instance Agda.Utils.Size.Sized Agda.Syntax.TopLevelModuleName.TopLevelModuleName
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.TopLevelModuleName.TopLevelModuleName
instance GHC.Classes.Eq Agda.Syntax.TopLevelModuleName.RawTopLevelModuleName
instance GHC.Classes.Ord Agda.Syntax.TopLevelModuleName.RawTopLevelModuleName
instance Agda.Utils.Size.Sized Agda.Syntax.TopLevelModuleName.RawTopLevelModuleName
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.TopLevelModuleName.RawTopLevelModuleName
instance Agda.Syntax.Position.HasRange Agda.Syntax.TopLevelModuleName.RawTopLevelModuleName
instance Agda.Syntax.Position.SetRange Agda.Syntax.TopLevelModuleName.RawTopLevelModuleName
instance Agda.Syntax.Position.KillRange Agda.Syntax.TopLevelModuleName.RawTopLevelModuleName
instance Agda.Syntax.Concrete.Name.IsNoName Agda.Syntax.TopLevelModuleName.RawTopLevelModuleName
instance Control.DeepSeq.NFData Agda.Syntax.TopLevelModuleName.RawTopLevelModuleName


-- | Pretty printer for the concrete syntax.
module Agda.Syntax.Concrete.Pretty
newtype Tel
Tel :: Telescope -> Tel
data NamedBinding
NamedBinding :: Bool -> NamedArg Binder -> NamedBinding
[withHiding] :: NamedBinding -> Bool
[namedBinding] :: NamedBinding -> NamedArg Binder

-- | <tt>prettyHiding info visible doc</tt> puts the correct braces around
--   <tt>doc</tt> according to info <tt>info</tt> and returns <tt>visible
--   doc</tt> if the we deal with a visible thing.
prettyHiding :: LensHiding a => a -> (Doc -> Doc) -> Doc -> Doc

-- | Show the attributes necessary to recover a modality, in long-form
--   (e.g. using at-syntax rather than dots). For the default modality, the
--   result is at-ω (rather than the empty document). Suitable for showing
--   modalities outside of binders.
attributesForModality :: Modality -> Doc
prettyRelevance :: LensRelevance a => a -> Doc -> Doc
bracesAndSemicolons :: Foldable t => t Doc -> Doc
prettyQuantity :: LensQuantity a => a -> Doc -> Doc
prettyLock :: LensLock a => a -> Doc -> Doc
prettyErased :: Erased -> Doc -> Doc
prettyCohesion :: LensCohesion a => a -> Doc -> Doc
prettyTactic :: BoundName -> Doc -> Doc
prettyTactic' :: TacticAttribute -> Doc -> Doc
prettyFiniteness :: BoundName -> Doc -> Doc
prettyOpApp :: forall a. Pretty a => Aspect -> QName -> [NamedArg (MaybePlaceholder a)] -> [Doc]
smashTel :: Telescope -> Telescope
isLabeled :: NamedArg Binder -> Maybe ArgName
pRecord :: Erased -> Name -> [RecordDirective] -> [LamBinding] -> Maybe Expr -> [Declaration] -> Doc
pHasEta0 :: HasEta0 -> Doc
pRecordDirective :: RecordDirective -> Doc
instance GHC.Show.Show Agda.Syntax.Concrete.Expr
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Concrete.OpApp a)
instance GHC.Show.Show Agda.Syntax.Concrete.Declaration
instance GHC.Show.Show Agda.Syntax.Concrete.Pattern
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Concrete.Binder' a)
instance GHC.Show.Show Agda.Syntax.Concrete.TypedBinding
instance GHC.Show.Show Agda.Syntax.Concrete.LamBinding
instance GHC.Show.Show Agda.Syntax.Concrete.BoundName
instance GHC.Show.Show Agda.Syntax.Concrete.ModuleAssignment
instance (GHC.Show.Show a, GHC.Show.Show b) => GHC.Show.Show (Agda.Syntax.Common.ImportDirective' a b)
instance (GHC.Show.Show a, GHC.Show.Show b) => GHC.Show.Show (Agda.Syntax.Common.Using' a b)
instance (GHC.Show.Show a, GHC.Show.Show b) => GHC.Show.Show (Agda.Syntax.Common.Renaming' a b)
instance GHC.Show.Show Agda.Syntax.Concrete.Pragma
instance GHC.Show.Show Agda.Syntax.Concrete.RHS
instance GHC.Show.Show Agda.Syntax.Concrete.LHS
instance GHC.Show.Show Agda.Syntax.Concrete.LHSCore
instance GHC.Show.Show Agda.Syntax.Concrete.LamClause
instance GHC.Show.Show Agda.Syntax.Concrete.WhereClause
instance GHC.Show.Show Agda.Syntax.Concrete.ModuleApplication
instance GHC.Show.Show Agda.Syntax.Concrete.DoStmt
instance GHC.Show.Show Agda.Syntax.Concrete.Module
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.Expr
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.Pretty.Tel
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.Pretty.NamedBinding
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.LamBinding
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.TypedBinding
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.Lock
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Concrete.TacticAttribute' a)
instance (Agda.Syntax.Common.Pretty.Pretty a, Agda.Syntax.Common.Pretty.Pretty b) => Agda.Syntax.Common.Pretty.Pretty (a, b)
instance Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Fixity.ThingWithFixity Agda.Syntax.Concrete.Name.Name)
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Common.WithHiding a)
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.Relevance
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.Q0Origin
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.Q1Origin
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.QωOrigin
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.Quantity
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.Erased
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.Cohesion
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.Modality
instance Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Concrete.OpApp Agda.Syntax.Concrete.Expr)
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Common.MaybePlaceholder a)
instance (Agda.Syntax.Common.Pretty.Pretty a, Agda.Syntax.Common.Pretty.Pretty b) => Agda.Syntax.Common.Pretty.Pretty (Data.Either.Either a b)
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Concrete.FieldAssignment' a)
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.ModuleAssignment
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.LamClause
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.BoundName
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Concrete.Binder' a)
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.RHS
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.WhereClause
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.LHS
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.LHSCore
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.ModuleApplication
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.DoStmt
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.Declaration
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.RecordDirective
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.OpenShortHand
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.Pragma
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.Associativity
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.FixityLevel
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.Fixity
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.NotationPart
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Common.Fixity'
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Common.Pretty.Pretty e => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Common.Named_ e)
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.Pattern
instance (Agda.Syntax.Common.Pretty.Pretty a, Agda.Syntax.Common.Pretty.Pretty b) => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Common.ImportDirective' a b)
instance (Agda.Syntax.Common.Pretty.Pretty a, Agda.Syntax.Common.Pretty.Pretty b) => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Common.Using' a b)
instance (Agda.Syntax.Common.Pretty.Pretty a, Agda.Syntax.Common.Pretty.Pretty b) => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Common.Renaming' a b)
instance (Agda.Syntax.Common.Pretty.Pretty a, Agda.Syntax.Common.Pretty.Pretty b) => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Common.ImportedName' a b)


-- | Split tree for transforming pattern clauses into case trees.
--   
--   The coverage checker generates a split tree from the clauses. The
--   clause compiler uses it to transform clauses to case trees.
--   
--   The initial problem is a set of clauses. The root node designates on
--   which argument to split and has subtrees for all the constructors.
--   Splitting continues until there is only a single clause left at each
--   leaf of the split tree.
module Agda.TypeChecking.Coverage.SplitTree
type SplitTree = SplitTree' SplitTag
type SplitTrees = SplitTrees' SplitTag

-- | Abstract case tree shape.
data SplitTree' a

-- | No more splits coming. We are at a single, all-variable clause.
SplittingDone :: Int -> SplitTree' a

-- | The number of variables bound in the clause
[splitBindings] :: SplitTree' a -> Int

-- | A split is necessary.
SplitAt :: Arg Int -> LazySplit -> SplitTrees' a -> SplitTree' a

-- | Arg. no to split at.
[splitArg] :: SplitTree' a -> Arg Int
[splitLazy] :: SplitTree' a -> LazySplit

-- | Sub split trees.
[splitTrees] :: SplitTree' a -> SplitTrees' a
data LazySplit
LazySplit :: LazySplit
StrictSplit :: LazySplit

-- | Split tree branching. A finite map from constructor names to
--   splittrees A list representation seems appropriate, since we are
--   expecting not so many constructors per data type, and there is no need
--   for random access.
type SplitTrees' a = [(a, SplitTree' a)]

-- | Tag for labeling branches of a split tree. Each branch is associated
--   to either a constructor or a literal, or is a catchall branch
--   (currently only used for splitting on a literal type).
data SplitTag
SplitCon :: QName -> SplitTag
SplitLit :: Literal -> SplitTag
SplitCatchall :: SplitTag
data SplitTreeLabel a
SplitTreeLabel :: Maybe a -> Maybe (Arg Int) -> LazySplit -> Maybe Int -> SplitTreeLabel a

-- | <a>Nothing</a> for root of split tree
[lblConstructorName] :: SplitTreeLabel a -> Maybe a
[lblSplitArg] :: SplitTreeLabel a -> Maybe (Arg Int)
[lblLazy] :: SplitTreeLabel a -> LazySplit
[lblBindings] :: SplitTreeLabel a -> Maybe Int

-- | Convert a split tree into a <a>Tree</a> (for printing).
toTree :: SplitTree' a -> Tree (SplitTreeLabel a)
toTrees :: SplitTrees' a -> Forest (SplitTreeLabel a)
instance GHC.Generics.Generic Agda.TypeChecking.Coverage.SplitTree.LazySplit
instance GHC.Classes.Ord Agda.TypeChecking.Coverage.SplitTree.LazySplit
instance GHC.Classes.Eq Agda.TypeChecking.Coverage.SplitTree.LazySplit
instance GHC.Show.Show Agda.TypeChecking.Coverage.SplitTree.LazySplit
instance GHC.Generics.Generic (Agda.TypeChecking.Coverage.SplitTree.SplitTree' a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.TypeChecking.Coverage.SplitTree.SplitTree' a)
instance GHC.Generics.Generic Agda.TypeChecking.Coverage.SplitTree.SplitTag
instance GHC.Classes.Ord Agda.TypeChecking.Coverage.SplitTree.SplitTag
instance GHC.Classes.Eq Agda.TypeChecking.Coverage.SplitTree.SplitTag
instance GHC.Show.Show Agda.TypeChecking.Coverage.SplitTree.SplitTag
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.Coverage.SplitTree.SplitTreeLabel a)
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Coverage.SplitTree.SplitTag
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Coverage.SplitTree.SplitTag
instance Control.DeepSeq.NFData Agda.TypeChecking.Coverage.SplitTree.SplitTag
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.Coverage.SplitTree.SplitTree' a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.TypeChecking.Coverage.SplitTree.SplitTree' a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.TypeChecking.Coverage.SplitTree.SplitTree' a)
instance Control.DeepSeq.NFData Agda.TypeChecking.Coverage.SplitTree.LazySplit


-- | As a concrete name, a notation is a non-empty list of alternating
--   <a>IdPart</a>s and holes. In contrast to concrete names, holes can be
--   binders.
--   
--   Example: <tt> syntax fmap (λ x → e) xs = for x ∈ xs return e </tt>
--   
--   The declared notation for <tt>fmap</tt> is <tt>for_∈_return_</tt>
--   where the first hole is a binder.
module Agda.Syntax.Notation

-- | Data type constructed in the Happy parser; converted to
--   <a>NotationPart</a> before it leaves the Happy code.
data HoleName

-- | <tt>λ x₁ … xₙ → y</tt>: The first argument contains the bound names.
LambdaHole :: List1 RString -> RString -> HoleName
[_bindHoleNames] :: HoleName -> List1 RString
[holeName] :: HoleName -> RString

-- | Simple named hole with hiding.
ExprHole :: RString -> HoleName
[holeName] :: HoleName -> RString

-- | Is the hole a binder?
isLambdaHole :: HoleName -> Bool

-- | Get a flat list of identifier parts of a notation.
stringParts :: Notation -> [String]

-- | Target argument position of a part (Nothing if it is not a hole).
holeTarget :: NotationPart -> Maybe Int

-- | Is the part a hole?
isAHole :: NotationPart -> Bool

-- | Is the part a binder?
isBinder :: NotationPart -> Bool

-- | Classification of notations.
data NotationKind

-- | Ex: <tt>_bla_blub_</tt>.
InfixNotation :: NotationKind

-- | Ex: <tt>_bla_blub</tt>.
PrefixNotation :: NotationKind

-- | Ex: <tt>bla_blub_</tt>.
PostfixNotation :: NotationKind

-- | Ex: <tt>bla_blub</tt>.
NonfixNotation :: NotationKind
NoNotation :: NotationKind

-- | Classify a notation by presence of leading and/or trailing
--   <i>normal</i> holes.
notationKind :: Notation -> NotationKind

-- | From notation with names to notation with indices.
--   
--   An example (with some parts of the code omitted): The lists
--   <tt>["for", "x", "∈", "xs", "return", "e"]</tt> and
--   <tt>[<a>LambdaHole</a> ("x" :| []) "e", <a>ExprHole</a> "xs"]</tt> are
--   mapped to the following notation: <tt> [ <a>IdPart</a> "for" ,
--   <a>VarPart</a> (<a>BoundVariablePosition</a> 0 0) , <a>IdPart</a> "∈"
--   , <a>HolePart</a> 1 , <a>IdPart</a> "return" , <a>HolePart</a> 0 ]
--   </tt>
mkNotation :: [NamedArg HoleName] -> [RString] -> Either String Notation

-- | All the notation information related to a name.
data NewNotation
NewNotation :: QName -> Set Name -> Fixity -> Notation -> Bool -> NewNotation
[notaName] :: NewNotation -> QName

-- | The names the syntax and/or fixity belong to.
--   
--   Invariant: The set is non-empty. Every name in the list matches
--   <a>notaName</a>.
[notaNames] :: NewNotation -> Set Name

-- | Associativity and precedence (fixity) of the names.
[notaFixity] :: NewNotation -> Fixity

-- | Syntax associated with the names.
[notation] :: NewNotation -> Notation

-- | True if the notation comes from an operator (rather than a syntax
--   declaration).
[notaIsOperator] :: NewNotation -> Bool

-- | If an operator has no specific notation, then it is computed from its
--   name.
namesToNotation :: QName -> Name -> NewNotation

-- | Replace <a>noFixity</a> by <a>defaultFixity</a>.
useDefaultFixity :: NewNotation -> NewNotation

-- | Return the <a>IdPart</a>s of a notation, the first part qualified, the
--   other parts unqualified. This allows for qualified use of operators,
--   e.g., <tt>M.for x ∈ xs return e</tt>, or <tt>x ℕ.+ y</tt>.
notationNames :: NewNotation -> [QName]

-- | Create a <a>Notation</a> (without binders) from a concrete
--   <a>Name</a>. Does the obvious thing: <a>Hole</a>s become
--   <a>HolePart</a>s, <a>Id</a>s become <tt>IdParts</tt>. If <a>Name</a>
--   has no <a>Hole</a>s, it returns <a>noNotation</a>.
syntaxOf :: Name -> Notation

-- | Merges <a>NewNotation</a>s that have the same precedence level and
--   notation, with two exceptions:
--   
--   <ul>
--   <li>Operators and notations coming from syntax declarations are kept
--   separate.</li>
--   <li>If <i>all</i> instances of a given <a>NewNotation</a> have the
--   same precedence level or are "unrelated", then they are merged. They
--   get the given precedence level, if any, and otherwise they become
--   unrelated (but related to each other).</li>
--   </ul>
--   
--   If <a>NewNotation</a>s that are merged have distinct associativities,
--   then they get <a>NonAssoc</a> as their associativity.
--   
--   Precondition: No <a>Name</a> may occur in more than one list element.
--   Every <a>NewNotation</a> must have the same <a>notaName</a>.
--   
--   Postcondition: No <a>Name</a> occurs in more than one list element.
mergeNotations :: List1 NewNotation -> List1 NewNotation

-- | Check if a notation contains any lambdas (in which case it cannot be
--   used in a pattern).
isLambdaNotation :: NewNotation -> Bool

-- | Lens for <a>Fixity</a> in <a>NewNotation</a>.
_notaFixity :: Lens' NewNotation Fixity

-- | Sections, as well as non-sectioned operators.
data NotationSection
NotationSection :: NewNotation -> NotationKind -> Maybe FixityLevel -> Bool -> NotationSection
[sectNotation] :: NotationSection -> NewNotation

-- | For non-sectioned operators this should match the notation's
--   <a>notationKind</a>.
[sectKind] :: NotationSection -> NotationKind

-- | Effective precedence level. <a>Nothing</a> for closed notations.
[sectLevel] :: NotationSection -> Maybe FixityLevel

-- | <a>False</a> for non-sectioned operators.
[sectIsSection] :: NotationSection -> Bool

-- | Converts a notation to a (non-)section.
noSection :: NewNotation -> NotationSection
instance GHC.Generics.Generic Agda.Syntax.Notation.NotationKind
instance GHC.Show.Show Agda.Syntax.Notation.NotationKind
instance GHC.Classes.Eq Agda.Syntax.Notation.NotationKind
instance GHC.Generics.Generic Agda.Syntax.Notation.NewNotation
instance GHC.Show.Show Agda.Syntax.Notation.NewNotation
instance GHC.Generics.Generic Agda.Syntax.Notation.NotationSection
instance GHC.Show.Show Agda.Syntax.Notation.NotationSection
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Notation.NotationSection
instance Control.DeepSeq.NFData Agda.Syntax.Notation.NotationSection
instance Agda.Syntax.Common.LensFixity Agda.Syntax.Notation.NewNotation
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Notation.NewNotation
instance Control.DeepSeq.NFData Agda.Syntax.Notation.NewNotation
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Notation.NotationKind
instance Control.DeepSeq.NFData Agda.Syntax.Notation.NotationKind

module Agda.Syntax.Internal.Elim

-- | Eliminations, subsuming applications and projections.
data Elim' a

-- | Application.
Apply :: Arg a -> Elim' a

-- | Projection. <a>QName</a> is name of a record projection.
Proj :: ProjOrigin -> QName -> Elim' a

-- | IApply x y r, x and y are the endpoints
IApply :: a -> a -> a -> Elim' a

-- | Drop <a>Apply</a> constructor. (Safe)
isApplyElim :: Elim' a -> Maybe (Arg a)
isApplyElim' :: Empty -> Elim' a -> Arg a

-- | Only <a>Apply</a> variant.
isProperApplyElim :: Elim' a -> Bool

-- | Drop <a>Apply</a> constructors. (Safe)
allApplyElims :: [Elim' a] -> Maybe [Arg a]

-- | Split at first non-<a>Apply</a>
splitApplyElims :: [Elim' a] -> ([Arg a], [Elim' a])
class IsProjElim e
isProjElim :: IsProjElim e => e -> Maybe (ProjOrigin, QName)

-- | Discards <tt>Proj f</tt> entries.
argsFromElims :: [Elim' t] -> [Arg t]

-- | Drop <a>Proj</a> constructors. (Safe)
allProjElims :: [Elim' t] -> Maybe [(ProjOrigin, QName)]
instance Data.Traversable.Traversable Agda.Syntax.Internal.Elim.Elim'
instance Data.Foldable.Foldable Agda.Syntax.Internal.Elim.Elim'
instance GHC.Base.Functor Agda.Syntax.Internal.Elim.Elim'
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.Syntax.Internal.Elim.IsProjElim (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.Syntax.Common.LensOrigin (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.Syntax.Common.Pretty.Pretty tm => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Internal.Elim.Elim' tm)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Internal.Elim.Elim' a)

module Agda.Syntax.Internal.Blockers

-- | Even if we are not stuck on a meta during reduction we can fail to
--   reduce a definition by pattern matching for another reason.
data NotBlocked' t

-- | The <tt>Elim</tt> is neutral and blocks a pattern match.
StuckOn :: Elim' t -> NotBlocked' t

-- | Not enough arguments were supplied to complete the matching.
Underapplied :: NotBlocked' t

-- | We matched an absurd clause, results in a neutral <tt>Def</tt>.
AbsurdMatch :: NotBlocked' t

-- | We ran out of clauses for <a>QName</a>, all considered clauses
--   produced an actual mismatch. This can happen when try to reduce a
--   function application but we are still missing some function clauses.
--   See <a>Agda.TypeChecking.Patterns.Match</a>.
MissingClauses :: QName -> NotBlocked' t

-- | Reduction was not blocked, we reached a whnf which can be anything but
--   a stuck <tt><tt>Def</tt></tt>.
ReallyNotBlocked :: NotBlocked' t

-- | What is causing the blocking? Or in other words which metas or
--   problems need to be solved to unblock the blocked
--   computation/constraint.
data Blocker
UnblockOnAll :: Set Blocker -> Blocker
UnblockOnAny :: Set Blocker -> Blocker

-- | Unblock if meta is instantiated
UnblockOnMeta :: MetaId -> Blocker
UnblockOnProblem :: ProblemId -> Blocker

-- | Unblock when function is defined
UnblockOnDef :: QName -> Blocker
alwaysUnblock :: Blocker
neverUnblock :: Blocker
unblockOnAll :: Set Blocker -> Blocker
unblockOnAny :: Set Blocker -> Blocker
unblockOnEither :: Blocker -> Blocker -> Blocker
unblockOnBoth :: Blocker -> Blocker -> Blocker
unblockOnMeta :: MetaId -> Blocker
unblockOnProblem :: ProblemId -> Blocker
unblockOnDef :: QName -> Blocker
unblockOnAllMetas :: Set MetaId -> Blocker
unblockOnAnyMeta :: Set MetaId -> Blocker
onBlockingMetasM :: Monad m => (MetaId -> m Blocker) -> Blocker -> m Blocker
allBlockingMetas :: Blocker -> Set MetaId
allBlockingProblems :: Blocker -> Set ProblemId
allBlockingDefs :: Blocker -> Set QName

-- | Something where a meta variable may block reduction. Notably a
--   top-level meta is considered blocking. This did not use to be the case
--   (pre Aug 2020).
data Blocked' t a
Blocked :: Blocker -> a -> Blocked' t a
[theBlocker] :: Blocked' t a -> Blocker
[ignoreBlocking] :: Blocked' t a -> a
NotBlocked :: NotBlocked' t -> a -> Blocked' t a
[blockingStatus] :: Blocked' t a -> NotBlocked' t
[ignoreBlocking] :: Blocked' t a -> a

-- | When trying to reduce <tt>f es</tt>, on match failed on one
--   elimination <tt>e ∈ es</tt> that came with info <tt>r ::
--   NotBlocked</tt>. <tt>stuckOn e r</tt> produces the new
--   <tt>NotBlocked</tt> info.
--   
--   <a>MissingClauses</a> must be propagated, as this is blockage that can
--   be lifted in the future (as more clauses are added).
--   
--   <tt><a>StuckOn</a> e0</tt> is also propagated, since it provides more
--   precise information as <tt>StuckOn e</tt> (as <tt>e0</tt> is the
--   original reason why reduction got stuck and usually a subterm of
--   <tt>e</tt>). An information like <tt>StuckOn (Apply (Arg info (Var i
--   [])))</tt> (stuck on a variable) could be used by the lhs/coverage
--   checker to trigger a split on that (pattern) variable.
--   
--   In the remaining cases for <tt>r</tt>, we are terminally stuck due to
--   <tt>StuckOn e</tt>. Propagating <tt><a>AbsurdMatch</a></tt> does not
--   seem useful.
--   
--   <a>Underapplied</a> must not be propagated, as this would mean that
--   <tt>f es</tt> is underapplied, which is not the case (it is stuck).
--   Note that <a>Underapplied</a> can only arise when projection patterns
--   were missing to complete the original match (in <tt>e</tt>). (Missing
--   ordinary pattern would mean the <tt>e</tt> is of function type, but we
--   cannot match against something of function type.)
stuckOn :: Elim' t -> NotBlocked' t -> NotBlocked' t
blockedOn :: Blocker -> a -> Blocked' t a
blocked :: MetaId -> a -> Blocked' t a
notBlocked :: a -> Blocked' t a
blocked_ :: MetaId -> Blocked' t ()
notBlocked_ :: Blocked' t ()
getBlocker :: Blocked' t a -> Blocker

-- | Should a constraint wake up or not? If not, we might refine the
--   unblocker.
data WakeUp
WakeUp :: WakeUp
DontWakeUp :: Maybe Blocker -> WakeUp
wakeUpWhen :: (constr -> Bool) -> (constr -> WakeUp) -> constr -> WakeUp
wakeUpWhen_ :: (constr -> Bool) -> constr -> WakeUp
wakeIfBlockedOnProblem :: ProblemId -> Blocker -> WakeUp
wakeIfBlockedOnMeta :: MetaId -> Blocker -> WakeUp
wakeIfBlockedOnDef :: QName -> Blocker -> WakeUp
unblockMeta :: MetaId -> Blocker -> Blocker
unblockProblem :: ProblemId -> Blocker -> Blocker
unblockDef :: QName -> Blocker -> Blocker
instance GHC.Generics.Generic (Agda.Syntax.Internal.Blockers.NotBlocked' t)
instance GHC.Show.Show t => GHC.Show.Show (Agda.Syntax.Internal.Blockers.NotBlocked' t)
instance GHC.Generics.Generic Agda.Syntax.Internal.Blockers.Blocker
instance GHC.Classes.Ord Agda.Syntax.Internal.Blockers.Blocker
instance GHC.Classes.Eq Agda.Syntax.Internal.Blockers.Blocker
instance GHC.Show.Show Agda.Syntax.Internal.Blockers.Blocker
instance GHC.Generics.Generic (Agda.Syntax.Internal.Blockers.Blocked' t a)
instance Data.Traversable.Traversable (Agda.Syntax.Internal.Blockers.Blocked' t)
instance Data.Foldable.Foldable (Agda.Syntax.Internal.Blockers.Blocked' t)
instance GHC.Base.Functor (Agda.Syntax.Internal.Blockers.Blocked' t)
instance (GHC.Show.Show t, GHC.Show.Show a) => GHC.Show.Show (Agda.Syntax.Internal.Blockers.Blocked' t a)
instance GHC.Classes.Eq Agda.Syntax.Internal.Blockers.WakeUp
instance GHC.Show.Show Agda.Syntax.Internal.Blockers.WakeUp
instance Agda.Utils.Functor.Decoration (Agda.Syntax.Internal.Blockers.Blocked' t)
instance GHC.Base.Applicative (Agda.Syntax.Internal.Blockers.Blocked' t)
instance GHC.Base.Semigroup a => GHC.Base.Semigroup (Agda.Syntax.Internal.Blockers.Blocked' t a)
instance (GHC.Base.Semigroup a, GHC.Base.Monoid a) => GHC.Base.Monoid (Agda.Syntax.Internal.Blockers.Blocked' t a)
instance (Control.DeepSeq.NFData t, Control.DeepSeq.NFData a) => Control.DeepSeq.NFData (Agda.Syntax.Internal.Blockers.Blocked' t a)
instance Control.DeepSeq.NFData Agda.Syntax.Internal.Blockers.Blocker
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Internal.Blockers.Blocker
instance GHC.Base.Semigroup (Agda.Syntax.Internal.Blockers.NotBlocked' t)
instance GHC.Base.Monoid (Agda.Syntax.Internal.Blockers.NotBlocked' t)
instance Control.DeepSeq.NFData t => Control.DeepSeq.NFData (Agda.Syntax.Internal.Blockers.NotBlocked' t)
instance Agda.Syntax.Common.Pretty.Pretty t => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Internal.Blockers.NotBlocked' t)

module Agda.Syntax.Internal

-- | Type of argument lists.
type Args = [Arg Term]
type Type = Type' Term

-- | A clause is a list of patterns and the clause body.
--   
--   The telescope contains the types of the pattern variables and the de
--   Bruijn indices say how to get from the order the variables occur in
--   the patterns to the order they occur in the telescope. The body binds
--   the variables in the order they appear in the telescope.
--   
--   <pre>
--   clauseTel ~ permute clausePerm (patternVars namedClausePats)
--   </pre>
--   
--   Terms in dot patterns are valid in the clause telescope.
--   
--   For the purpose of the permutation and the body dot patterns count as
--   variables. TODO: Change this!
data Clause
Clause :: Range -> Range -> Telescope -> NAPs -> Maybe Term -> Maybe (Arg Type) -> Bool -> Maybe Bool -> Maybe Bool -> Maybe Bool -> ExpandedEllipsis -> Maybe ModuleName -> Clause
[clauseLHSRange] :: Clause -> Range
[clauseFullRange] :: Clause -> Range

-- | <tt>Δ</tt>: The types of the pattern variables in dependency order.
[clauseTel] :: Clause -> Telescope

-- | <tt>Δ ⊢ ps</tt>. The de Bruijn indices refer to <tt>Δ</tt>.
[namedClausePats] :: Clause -> NAPs

-- | <tt>Just v</tt> with <tt>Δ ⊢ v</tt> for a regular clause, or
--   <tt>Nothing</tt> for an absurd one.
[clauseBody] :: Clause -> Maybe Term

-- | <tt>Δ ⊢ t</tt>. The type of the rhs under <tt>clauseTel</tt>. Used,
--   e.g., by <tt>TermCheck</tt>. Can be <a>Irrelevant</a> if we
--   encountered an irrelevant projection pattern on the lhs.
[clauseType] :: Clause -> Maybe (Arg Type)

-- | Clause has been labelled as CATCHALL.
[clauseCatchall] :: Clause -> Bool

-- | Pattern matching of this clause is exact, no catch-all case. Computed
--   by the coverage checker. <tt>Nothing</tt> means coverage checker has
--   not run yet (clause may be inexact). <tt>Just False</tt> means clause
--   is not exact. <tt>Just True</tt> means clause is exact.
[clauseExact] :: Clause -> Maybe Bool

-- | <tt>clauseBody</tt> contains recursive calls; computed by termination
--   checker. <tt>Nothing</tt> means that termination checker has not run
--   yet, or that <tt>clauseBody</tt> contains meta-variables; these could
--   be filled with recursive calls later! <tt>Just False</tt> means
--   definitely no recursive call. <tt>Just True</tt> means definitely a
--   recursive call.
[clauseRecursive] :: Clause -> Maybe Bool

-- | Clause has been labelled as unreachable by the coverage checker.
--   <tt>Nothing</tt> means coverage checker has not run yet (clause may be
--   unreachable). <tt>Just False</tt> means clause is not unreachable.
--   <tt>Just True</tt> means clause is unreachable.
[clauseUnreachable] :: Clause -> Maybe Bool

-- | Was this clause created by expansion of an ellipsis?
[clauseEllipsis] :: Clause -> ExpandedEllipsis

-- | Keeps track of the module name associate with the clause's where
--   clause.
[clauseWhereModule] :: Clause -> Maybe ModuleName

-- | Raw values.
--   
--   <tt>Def</tt> is used for both defined and undefined constants. Assume
--   there is a type declaration and a definition for every constant, even
--   if the definition is an empty list of clauses.
data Term

-- | <tt>x es</tt> neutral
Var :: {-# UNPACK #-} !Int -> Elims -> Term

-- | Terms are beta normal. Relevance is ignored
Lam :: ArgInfo -> Abs Term -> Term
Lit :: Literal -> Term

-- | <tt>f es</tt>, possibly a delta/iota-redex
Def :: QName -> Elims -> Term

-- | <tt>c es</tt> or <tt>record { fs = es }</tt> <tt>es</tt> allows only
--   Apply and IApply eliminations, and IApply only for data constructors.
Con :: ConHead -> ConInfo -> Elims -> Term

-- | dependent or non-dependent function space
Pi :: Dom Type -> Abs Type -> Term
Sort :: Sort -> Term
Level :: Level -> Term
MetaV :: {-# UNPACK #-} !MetaId -> Elims -> Term

-- | Irrelevant stuff in relevant position, but created in an irrelevant
--   context. Basically, an internal version of the irrelevance axiom
--   <tt>.irrAx : .A -&gt; A</tt>.
DontCare :: Term -> Term

-- | A (part of a) term or type which is only used for internal purposes.
--   Replaces the <tt>Sort Prop</tt> hack. The <tt>String</tt> typically
--   describes the location where we create this dummy, but can contain
--   other information as well. The second field accumulates eliminations
--   in case we apply a dummy term to more of them. Dummy terms should
--   never be used in places where they can affect type checking, so
--   syntactic checks are free to ignore the eliminators, which are only
--   there to ease debugging when a dummy term incorrectly leaks into a
--   relevant position.
Dummy :: String -> Elims -> Term
type Pattern = -- | The @PatVarName@ is a name suggestion. Pattern' PatVarName
type Telescope = Tele (Dom Type)
type Substitution = Substitution' Term

-- | Similar to <a>Arg</a>, but we need to distinguish an irrelevance
--   annotation in a function domain (the domain itself is not irrelevant!)
--   from an irrelevant argument.
--   
--   <tt>Dom</tt> is used in <a>Pi</a> of internal syntax, in
--   <tt>Context</tt> and <a>Telescope</a>. <a>Arg</a> is used for actual
--   arguments (<a>Var</a>, <a>Con</a>, <a>Def</a> etc.) and in
--   <tt>Abstract</tt> syntax and other situations.
--   
--   <ul>
--   <li><i> cubical </i> When <tt>annFinite (argInfoAnnotation domInfo) =
--   True</tt> for the domain of a <a>Pi</a> type, the elements should be
--   compared by tabulating the domain type. Only supported in case the
--   domain type is primIsOne, to obtain the correct equality for partial
--   elements.</li>
--   </ul>
data Dom' t e
Dom :: ArgInfo -> Maybe NamedName -> Bool -> Maybe t -> e -> Dom' t e
[domInfo] :: Dom' t e -> ArgInfo

-- | e.g. <tt>x</tt> in <tt>{x = y : A} -&gt; B</tt>.
[domName] :: Dom' t e -> Maybe NamedName

-- | Is this a Π-type (False), or a partial type (True)?
[domIsFinite] :: Dom' t e -> Bool

-- | "@tactic e".
[domTactic] :: Dom' t e -> Maybe t
[unDom] :: Dom' t e -> e
type Dom = Dom' Term
type Level = Level' Term
type Elim = Elim' Term
type Sort = Sort' Term
type DataOrRecord = DataOrRecord' PatternOrCopattern

-- | Substitutions.
data Substitution' a

-- | Identity substitution. <tt>Γ ⊢ IdS : Γ</tt>
IdS :: Substitution' a

-- | Empty substitution, lifts from the empty context. First argument is
--   <tt><b>IMPOSSIBLE</b></tt>. Apply this to closed terms you want to use
--   in a non-empty context. <tt>Γ ⊢ EmptyS : ()</tt>
EmptyS :: Impossible -> Substitution' a

-- | Substitution extension, `<tt>cons'</tt>. <tt> Γ ⊢ u : Aρ Γ ⊢ ρ : Δ
--   ---------------------- Γ ⊢ u :# ρ : Δ, A </tt>
(:#) :: a -> Substitution' a -> Substitution' a

-- | Strengthening substitution. First argument is
--   <tt><b>IMPOSSIBLE</b></tt>. In <tt>'Strengthen err n ρ</tt> the number
--   <tt>n</tt> must be non-negative. This substitution should only be
--   applied to values <tt>t</tt> for which none of the variables
--   <tt>0</tt> up to <tt>n - 1</tt> are free in <tt>t[ρ]</tt>, and in that
--   case <tt>n</tt> is subtracted from all free de Bruijn indices in
--   <tt>t[ρ]</tt>. Γ ⊢ ρ : Δ |Θ| = n --------------------------- Γ ⊢
--   Strengthen n ρ : Δ, Θ @
Strengthen :: Impossible -> !Int -> Substitution' a -> Substitution' a

-- | Weakening substitution, lifts to an extended context. <tt> Γ ⊢ ρ : Δ
--   ------------------- Γ, Ψ ⊢ Wk |Ψ| ρ : Δ </tt>
Wk :: !Int -> Substitution' a -> Substitution' a

-- | Lifting substitution. Use this to go under a binder. <tt>Lift 1 ρ ==
--   var 0 :# Wk 1 ρ</tt>. <tt> Γ ⊢ ρ : Δ ------------------------- Γ, Ψρ ⊢
--   Lift |Ψ| ρ : Δ, Ψ </tt>
Lift :: !Int -> Substitution' a -> Substitution' a
infixr 4 :#

-- | Binder.
--   
--   <a>Abs</a>: The bound variable might appear in the body. <a>NoAbs</a>
--   is pseudo-binder, it does not introduce a fresh variable, similar to
--   the <tt>const</tt> of Haskell.
data Abs a

-- | The body has (at least) one free variable. Danger: <a>unAbs</a>
--   doesn't shift variables properly
Abs :: ArgName -> a -> Abs a
[absName] :: Abs a -> ArgName
[unAbs] :: Abs a -> a
NoAbs :: ArgName -> a -> Abs a
[absName] :: Abs a -> ArgName
[unAbs] :: Abs a -> a
class LensSort a
lensSort :: LensSort a => Lens' a Sort
getSort :: LensSort a => a -> Sort
type Elims = -- | eliminations ordered left-to-right. [Elim]

-- | The size of a term is roughly the number of nodes in its syntax tree.
--   This number need not be precise for logical correctness of Agda, it is
--   only used for reporting (and maybe decisions regarding performance).
--   
--   Not counting towards the term size are:
--   
--   <ul>
--   <li>sort and color annotations,</li>
--   <li>projections.</li>
--   </ul>
class TermSize a
termSize :: TermSize a => a -> Int
tsize :: TermSize a => a -> Sum Int
type Blocked = Blocked' Term
type NotBlocked = NotBlocked' Term
type NamedArgs = [NamedArg Term]
data DataOrRecord' p
IsData :: DataOrRecord' p
IsRecord :: p -> DataOrRecord' p

-- | Store the names of the record fields in the constructor. This allows
--   reduction of projection redexes outside of TCM. For instance, during
--   substitution and application.
data ConHead
ConHead :: QName -> DataOrRecord -> Induction -> [Arg QName] -> ConHead

-- | The name of the constructor.
[conName] :: ConHead -> QName

-- | Data or record constructor?
[conDataRecord] :: ConHead -> DataOrRecord

-- | Record constructors can be coinductive.
[conInductive] :: ConHead -> Induction

-- | The name of the record fields. <a>Arg</a> is stored since the info in
--   the constructor args might not be accurate because of subtyping (issue
--   #2170).
[conFields] :: ConHead -> [Arg QName]
class LensConName a
getConName :: LensConName a => a -> QName
setConName :: LensConName a => QName -> a -> a
mapConName :: LensConName a => (QName -> QName) -> a -> a
type ConInfo = ConOrigin

-- | Types are terms with a sort annotation.
data Type'' t a
El :: Sort' t -> a -> Type'' t a
[_getSort] :: Type'' t a -> Sort' t
[unEl] :: Type'' t a -> a

-- | Sorts.
data Sort' t

-- | <tt>Prop ℓ</tt>, <tt>Set ℓ</tt>, <tt>SSet ℓ</tt>.
Univ :: Univ -> Level' t -> Sort' t

-- | <tt>Propωᵢ</tt>, <tt>(S)Setωᵢ</tt>.
Inf :: Univ -> !Integer -> Sort' t

-- | <tt>SizeUniv</tt>, a sort inhabited by type <tt>Size</tt>.
SizeUniv :: Sort' t

-- | <tt>LockUniv</tt>, a sort for locks.
LockUniv :: Sort' t

-- | <tt>LevelUniv</tt>, a sort inhabited by type <tt>Level</tt>. When
--   --level-universe isn't on, this universe reduces to <tt>Set 0</tt>
LevelUniv :: Sort' t

-- | <tt>IntervalUniv</tt>, a sort inhabited by the cubical interval.
IntervalUniv :: Sort' t

-- | Sort of the pi type.
PiSort :: Dom' t t -> Sort' t -> Abs (Sort' t) -> Sort' t

-- | Sort of a (non-dependent) function type.
FunSort :: Sort' t -> Sort' t -> Sort' t

-- | Sort of another sort.
UnivSort :: Sort' t -> Sort' t
MetaS :: {-# UNPACK #-} !MetaId -> [Elim' t] -> Sort' t

-- | A postulated sort.
DefS :: QName -> [Elim' t] -> Sort' t

-- | A (part of a) term or type which is only used for internal purposes.
--   Replaces the abuse of <tt>Prop</tt> for a dummy sort. The
--   <tt>String</tt> typically describes the location where we create this
--   dummy, but can contain other information as well.
DummyS :: String -> Sort' t
type Type' a = Type'' Term a

-- | Sequence of types. An argument of the first type is bound in later
--   types and so on.
data Tele a
EmptyTel :: Tele a

-- | <a>Abs</a> is never <a>NoAbs</a>.
ExtendTel :: a -> Abs (Tele a) -> Tele a
data UnivSize

-- | <tt>Prop<i>Set</i>SSet ℓ</tt>.
USmall :: UnivSize

-- | <tt>(Prop<i>Set</i>SSet)ωᵢ</tt>.
ULarge :: UnivSize

-- | A level is a maximum expression of a closed level and 0..n
--   <a>PlusLevel</a> expressions each of which is an atom plus a number.
data Level' t
Max :: !Integer -> [PlusLevel' t] -> Level' t
data PlusLevel' t
Plus :: !Integer -> t -> PlusLevel' t
type PlusLevel = PlusLevel' Term
type LevelAtom = Term

-- | Newtypes for terms that produce a dummy, rather than crash, when
--   applied to incompatible eliminations.
newtype BraveTerm
BraveTerm :: Term -> BraveTerm
[unBrave] :: BraveTerm -> Term

-- | <tt>'Blocked a</tt> without the <tt>a</tt>.
type Blocked_ = Blocked ()

-- | Named pattern arguments.
type NAPs = [NamedArg DeBruijnPattern]
type DeBruijnPattern = Pattern' DBPatVar

-- | Pattern variables.
type PatVarName = ArgName
data PatternInfo
PatternInfo :: PatOrigin -> [Name] -> PatternInfo
[patOrigin] :: PatternInfo -> PatOrigin
[patAsNames] :: PatternInfo -> [Name]

-- | Origin of the pattern: what did the user write in this position?
data PatOrigin

-- | Pattern inserted by the system
PatOSystem :: PatOrigin

-- | Pattern generated by case split
PatOSplit :: PatOrigin

-- | User wrote a variable pattern
PatOVar :: Name -> PatOrigin

-- | User wrote a dot pattern
PatODot :: PatOrigin

-- | User wrote a wildcard pattern
PatOWild :: PatOrigin

-- | User wrote a constructor pattern
PatOCon :: PatOrigin

-- | User wrote a record pattern
PatORec :: PatOrigin

-- | User wrote a literal pattern
PatOLit :: PatOrigin

-- | User wrote an absurd pattern
PatOAbsurd :: PatOrigin

-- | Patterns are variables, constructors, or wildcards. <tt>QName</tt> is
--   used in <tt>ConP</tt> rather than <tt>Name</tt> since a constructor
--   might come from a particular namespace. This also meshes well with the
--   fact that values (i.e. the arguments we are matching with) use
--   <tt>QName</tt>.
data Pattern' x

-- | <pre>
--   x
--   </pre>
VarP :: PatternInfo -> x -> Pattern' x

-- | <pre>
--   .t
--   </pre>
DotP :: PatternInfo -> Term -> Pattern' x

-- | <tt>c ps</tt> The subpatterns do not contain any projection
--   copatterns.
ConP :: ConHead -> ConPatternInfo -> [NamedArg (Pattern' x)] -> Pattern' x

-- | E.g. <tt>5</tt>, <tt>"hello"</tt>.
LitP :: PatternInfo -> Literal -> Pattern' x

-- | Projection copattern. Can only appear by itself.
ProjP :: ProjOrigin -> QName -> Pattern' x

-- | Path elimination pattern, like <tt>VarP</tt> but keeps track of
--   endpoints.
IApplyP :: PatternInfo -> Term -> Term -> x -> Pattern' x

-- | Used for HITs, the QName should be the one from primHComp.
DefP :: PatternInfo -> QName -> [NamedArg (Pattern' x)] -> Pattern' x

-- | The <tt>ConPatternInfo</tt> states whether the constructor belongs to
--   a record type (<tt>True</tt>) or data type (<tt>False</tt>). In the
--   former case, the <tt>PatOrigin</tt> of the <tt>conPInfo</tt> says
--   whether the record pattern orginates from the expansion of an implicit
--   pattern. The <tt>Type</tt> is the type of the whole record pattern.
--   The scope used for the type is given by any outer scope plus the
--   clause's telescope (<a>clauseTel</a>).
data ConPatternInfo
ConPatternInfo :: PatternInfo -> Bool -> Bool -> Maybe (Arg Type) -> Bool -> ConPatternInfo

-- | Information on the origin of the pattern.
[conPInfo] :: ConPatternInfo -> PatternInfo

-- | <tt>False</tt> if data constructor. <tt>True</tt> if record
--   constructor.
[conPRecord] :: ConPatternInfo -> Bool

-- | Should the match block on non-canonical terms or can it proceed to the
--   catch-all clause?
[conPFallThrough] :: ConPatternInfo -> Bool

-- | The type of the whole constructor pattern. Should be present
--   (<tt>Just</tt>) if constructor pattern is is generated ordinarily by
--   type-checking. Could be absent (<tt>Nothing</tt>) if pattern comes
--   from some plugin (like Agsy). Needed e.g. for with-clause stripping.
[conPType] :: ConPatternInfo -> Maybe (Arg Type)

-- | Lazy patterns are generated by the forcing translation in the unifier
--   (<a>unifyStep</a>) and are dropped by the clause compiler (TODO: not
--   yet) (<a>compileClauses</a>) when the variables they bind are unused.
--   The GHC backend compiles lazy matches to lazy patterns in Haskell
--   (TODO: not yet).
[conPLazy] :: ConPatternInfo -> Bool

-- | Type used when numbering pattern variables.
data DBPatVar
DBPatVar :: PatVarName -> !Int -> DBPatVar
[dbPatVarName] :: DBPatVar -> PatVarName
[dbPatVarIndex] :: DBPatVar -> !Int

-- | Extract pattern variables in left-to-right order. A <a>DotP</a> is
--   also treated as variable (see docu for <a>Clause</a>).
class PatternVars a where {
    type PatternVarOut a;
}
patternVars :: PatternVars a => a -> [Arg (Either (PatternVarOut a) Term)]
type PatternSubstitution = Substitution' DeBruijnPattern

-- | View type as equality type.
data EqualityView
EqualityViewType :: EqualityTypeData -> EqualityView

-- | reduced
OtherType :: Type -> EqualityView

-- | reduced
IdiomType :: Type -> EqualityView
data EqualityTypeData
EqualityTypeData :: Sort -> QName -> Args -> Arg Term -> Arg Term -> Arg Term -> EqualityTypeData

-- | Sort of this type.
[_eqtSort] :: EqualityTypeData -> Sort

-- | Builtin EQUALITY.
[_eqtName] :: EqualityTypeData -> QName

-- | Hidden. Empty or <tt>Level</tt>.
[_eqtParams] :: EqualityTypeData -> Args

-- | Hidden.
[_eqtType] :: EqualityTypeData -> Arg Term

-- | NotHidden.
[_eqtLhs] :: EqualityTypeData -> Arg Term

-- | NotHidden.
[_eqtRhs] :: EqualityTypeData -> Arg Term

-- | View type as path type.
data PathView
PathType :: Sort -> QName -> Arg Term -> Arg Term -> Arg Term -> Arg Term -> PathView

-- | Sort of this type.
[pathSort] :: PathView -> Sort

-- | Builtin PATH.
[pathName] :: PathView -> QName

-- | Hidden
[pathLevel] :: PathView -> Arg Term

-- | Hidden
[pathType] :: PathView -> Arg Term

-- | NotHidden
[pathLhs] :: PathView -> Arg Term

-- | NotHidden
[pathRhs] :: PathView -> Arg Term

-- | reduced
OType :: Type -> PathView
data IntervalView
IZero :: IntervalView
IOne :: IntervalView
IMin :: Arg Term -> Arg Term -> IntervalView
IMax :: Arg Term -> Arg Term -> IntervalView
INeg :: Arg Term -> IntervalView
OTerm :: Term -> IntervalView
type DummyTermKind = String

-- | Telescope as list.
type ListTel' a = [Dom (a, Type)]
type ListTel = ListTel' ArgName

-- | Drop the types from a telescope.
class TelToArgs a
telToArgs :: TelToArgs a => a -> [Arg ArgName]

-- | Constructing a singleton telescope.
class SgTel a
sgTel :: SgTel a => a -> Telescope

-- | Suggest a name if available (i.e. name is not "_")
class Suggest a
suggestName :: Suggest a => a -> Maybe String
data Suggestion
Suggestion :: a -> Suggestion
type family TypeOf a
pattern Prop :: Level' t -> Sort' t
pattern Type :: Level' t -> Sort' t
pattern SSet :: Level' t -> Sort' t
pattern EqualityType :: Sort -> QName -> Args -> Arg Term -> Arg Term -> Arg Term -> EqualityView

-- | Constant level <tt>n</tt>
pattern ClosedLevel :: Integer -> Level

-- | An unapplied variable.
var :: Nat -> Term
litP :: Literal -> Pattern' a
varP :: a -> Pattern' a
mkType :: Integer -> Sort

-- | Convert a telescope to its list form.
telToList :: Tele (Dom t) -> [Dom (ArgName, t)]

-- | Doesn't do any reduction.
arity :: Type -> Nat
argFromDom :: Dom' t a -> Arg a
namedArgFromDom :: Dom' t a -> NamedArg a
domFromArg :: Arg a -> Dom a
domFromNamedArg :: NamedArg a -> Dom a
defaultDom :: a -> Dom a
defaultArgDom :: ArgInfo -> a -> Dom a
defaultNamedArgDom :: ArgInfo -> String -> a -> Dom a

-- | Is this a strict universe inhabitable by data types?
isStrictDataSort :: Sort' t -> Bool
clausePats :: Clause -> [Arg DeBruijnPattern]
patVarNameToString :: PatVarName -> String
nameToPatVarName :: Name -> PatVarName
defaultPatternInfo :: PatternInfo
dotP :: Term -> Pattern' a
namedVarP :: PatVarName -> Named_ Pattern
namedDBVarP :: Int -> PatVarName -> Named_ DeBruijnPattern

-- | Make an absurd pattern with the given de Bruijn index.
absurdP :: Int -> DeBruijnPattern
absurdPatternName :: PatVarName
noConPatternInfo :: ConPatternInfo

-- | Build partial <a>ConPatternInfo</a> from <a>ConInfo</a>
toConPatternInfo :: ConInfo -> ConPatternInfo

-- | Build <a>ConInfo</a> from <a>ConPatternInfo</a>.
fromConPatternInfo :: ConPatternInfo -> ConInfo

-- | Retrieve the PatternInfo from a pattern
patternInfo :: Pattern' x -> Maybe PatternInfo

-- | Retrieve the origin of a pattern
patternOrigin :: Pattern' x -> Maybe PatOrigin

-- | Does the pattern perform a match that could fail?
properlyMatching :: Pattern' a -> Bool
properlyMatching' :: Bool -> Bool -> Pattern' a -> Bool
eqtSort :: EqualityView -> Sort
eqtName :: EqualityView -> QName
eqtParams :: EqualityView -> Args
eqtType :: EqualityView -> Arg Term
eqtLhs :: EqualityView -> Arg Term
eqtRhs :: EqualityView -> Arg Term
isEqualityType :: EqualityView -> Bool
isPathType :: PathView -> Bool
isIOne :: IntervalView -> Bool

-- | Absurd lambdas are internally represented as identity with variable
--   name "()".
absurdBody :: Abs Term
isAbsurdBody :: Abs Term -> Bool
isAbsurdPatternName :: PatVarName -> Bool

-- | Add <a>DontCare</a> is it is not already a <tt>DontCare</tt>.
dontCare :: Term -> Term

-- | Construct a string representing the call-site that created the dummy
--   thing.
dummyLocName :: CallStack -> String

-- | Aux: A dummy term to constitute a dummy term<i>level</i>sort/type.
dummyTermWith :: DummyTermKind -> CallStack -> Term

-- | A dummy level to constitute a level/sort created at location. Note:
--   use macro <b>DUMMY_LEVEL</b> !
dummyLevel :: CallStack -> Level
atomicLevel :: t -> Level' t

-- | A dummy term created at location. Note: use macro <b>DUMMY_TERM</b> !
dummyTerm :: CallStack -> Term
__DUMMY_TERM__ :: HasCallStack => Term
__DUMMY_LEVEL__ :: HasCallStack => Level

-- | A dummy sort created at location. Note: use macro <b>DUMMY_SORT</b> !
dummySort :: CallStack -> Sort
__DUMMY_SORT__ :: HasCallStack => Sort

-- | A dummy type created at location. Note: use macro <b>DUMMY_TYPE</b> !
dummyType :: CallStack -> Type
__DUMMY_TYPE__ :: HasCallStack => Type

-- | Context entries without a type have this dummy type. Note: use macro
--   <b>DUMMY_DOM</b> !
dummyDom :: CallStack -> Dom Type
__DUMMY_DOM__ :: HasCallStack => Dom Type
varSort :: Int -> Sort
tmSort :: Term -> Sort
tmSSort :: Term -> Sort

-- | Given a constant <tt>m</tt> and level <tt>l</tt>, compute <tt>m +
--   l</tt>
levelPlus :: Integer -> Level -> Level
levelSuc :: Level -> Level
mkProp :: Integer -> Sort
mkSSet :: Integer -> Sort
isSort :: Term -> Maybe Sort
impossibleTerm :: CallStack -> Term

-- | A traversal for the names in a telescope.
mapAbsNamesM :: Applicative m => (ArgName -> m ArgName) -> Tele a -> m (Tele a)
mapAbsNames :: (ArgName -> ArgName) -> Tele a -> Tele a
replaceEmptyName :: ArgName -> Tele a -> Tele a
telFromList' :: (a -> ArgName) -> ListTel' a -> Telescope

-- | Convert a list telescope to a telescope.
telFromList :: ListTel -> Telescope

-- | Lens to edit a <a>Telescope</a> as a list.
listTel :: Lens' Telescope ListTel

-- | Removing a topmost <a>DontCare</a> constructor.
stripDontCare :: Term -> Term
suggests :: [Suggestion] -> String

-- | Convert top-level postfix projections into prefix projections.
unSpine :: Term -> Term

-- | Convert <a>Proj</a> projection eliminations according to their
--   <a>ProjOrigin</a> into <a>Def</a> projection applications.
unSpine' :: (ProjOrigin -> QName -> Bool) -> Term -> Term

-- | A view distinguishing the neutrals <tt>Var</tt>, <tt>Def</tt>, and
--   <tt>MetaV</tt> which can be projected.
hasElims :: Term -> Maybe (Elims -> Term, Elims)
pDom :: LensHiding a => a -> Doc -> Doc
prettyPrecLevelSucs :: Int -> Integer -> (Int -> Doc) -> Doc

-- | Meta-variable identifiers use the same structure as <a>NameId</a>s.
data MetaId
MetaId :: {-# UNPACK #-} !Word64 -> {-# UNPACK #-} !ModuleNameHash -> MetaId
[metaId] :: MetaId -> {-# UNPACK #-} !Word64
[metaModule] :: MetaId -> {-# UNPACK #-} !ModuleNameHash

-- | A "problem" consists of a set of constraints and the same constraint
--   can be part of multiple problems.
newtype ProblemId
ProblemId :: Nat -> ProblemId
instance Data.Traversable.Traversable (Agda.Syntax.Internal.Dom' t)
instance Data.Foldable.Foldable (Agda.Syntax.Internal.Dom' t)
instance GHC.Base.Functor (Agda.Syntax.Internal.Dom' t)
instance (GHC.Show.Show t, GHC.Show.Show e) => GHC.Show.Show (Agda.Syntax.Internal.Dom' t e)
instance GHC.Generics.Generic (Agda.Syntax.Internal.DataOrRecord' p)
instance GHC.Classes.Eq p => GHC.Classes.Eq (Agda.Syntax.Internal.DataOrRecord' p)
instance GHC.Show.Show p => GHC.Show.Show (Agda.Syntax.Internal.DataOrRecord' p)
instance GHC.Generics.Generic Agda.Syntax.Internal.ConHead
instance GHC.Show.Show Agda.Syntax.Internal.ConHead
instance GHC.Generics.Generic (Agda.Syntax.Internal.Abs a)
instance Data.Traversable.Traversable Agda.Syntax.Internal.Abs
instance Data.Foldable.Foldable Agda.Syntax.Internal.Abs
instance GHC.Base.Functor Agda.Syntax.Internal.Abs
instance GHC.Generics.Generic (Agda.Syntax.Internal.Tele a)
instance Data.Traversable.Traversable Agda.Syntax.Internal.Tele
instance Data.Foldable.Foldable Agda.Syntax.Internal.Tele
instance GHC.Base.Functor Agda.Syntax.Internal.Tele
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Internal.Tele a)
instance GHC.Show.Show Agda.Syntax.Internal.UnivSize
instance GHC.Classes.Eq Agda.Syntax.Internal.UnivSize
instance Data.Traversable.Traversable Agda.Syntax.Internal.PlusLevel'
instance Data.Foldable.Foldable Agda.Syntax.Internal.PlusLevel'
instance GHC.Base.Functor Agda.Syntax.Internal.PlusLevel'
instance GHC.Show.Show t => GHC.Show.Show (Agda.Syntax.Internal.PlusLevel' t)
instance Data.Traversable.Traversable Agda.Syntax.Internal.Level'
instance Data.Foldable.Foldable Agda.Syntax.Internal.Level'
instance GHC.Base.Functor Agda.Syntax.Internal.Level'
instance GHC.Show.Show t => GHC.Show.Show (Agda.Syntax.Internal.Level' t)
instance GHC.Show.Show t => GHC.Show.Show (Agda.Syntax.Internal.Sort' t)
instance Data.Traversable.Traversable (Agda.Syntax.Internal.Type'' t)
instance Data.Foldable.Foldable (Agda.Syntax.Internal.Type'' t)
instance GHC.Base.Functor (Agda.Syntax.Internal.Type'' t)
instance (GHC.Show.Show t, GHC.Show.Show a) => GHC.Show.Show (Agda.Syntax.Internal.Type'' t a)
instance GHC.Show.Show Agda.Syntax.Internal.Term
instance GHC.Show.Show Agda.Syntax.Internal.BraveTerm
instance GHC.Generics.Generic Agda.Syntax.Internal.PatOrigin
instance GHC.Classes.Eq Agda.Syntax.Internal.PatOrigin
instance GHC.Show.Show Agda.Syntax.Internal.PatOrigin
instance GHC.Generics.Generic Agda.Syntax.Internal.PatternInfo
instance GHC.Classes.Eq Agda.Syntax.Internal.PatternInfo
instance GHC.Show.Show Agda.Syntax.Internal.PatternInfo
instance GHC.Generics.Generic Agda.Syntax.Internal.DBPatVar
instance GHC.Classes.Eq Agda.Syntax.Internal.DBPatVar
instance GHC.Show.Show Agda.Syntax.Internal.DBPatVar
instance GHC.Generics.Generic Agda.Syntax.Internal.ConPatternInfo
instance GHC.Show.Show Agda.Syntax.Internal.ConPatternInfo
instance GHC.Generics.Generic (Agda.Syntax.Internal.Pattern' x)
instance Data.Traversable.Traversable Agda.Syntax.Internal.Pattern'
instance Data.Foldable.Foldable Agda.Syntax.Internal.Pattern'
instance GHC.Base.Functor Agda.Syntax.Internal.Pattern'
instance GHC.Show.Show x => GHC.Show.Show (Agda.Syntax.Internal.Pattern' x)
instance GHC.Generics.Generic Agda.Syntax.Internal.Clause
instance GHC.Show.Show Agda.Syntax.Internal.Clause
instance GHC.Generics.Generic (Agda.Syntax.Internal.Substitution' a)
instance Data.Traversable.Traversable Agda.Syntax.Internal.Substitution'
instance Data.Foldable.Foldable Agda.Syntax.Internal.Substitution'
instance GHC.Base.Functor Agda.Syntax.Internal.Substitution'
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Internal.Substitution' a)
instance GHC.Show.Show Agda.Syntax.Internal.IntervalView
instance (Data.Foldable.Foldable t, Agda.Syntax.Internal.TermSize a) => Agda.Syntax.Internal.TermSize (t a)
instance Agda.Syntax.Internal.TermSize Agda.Syntax.Internal.Term
instance Agda.Syntax.Internal.TermSize Agda.Syntax.Internal.Sort
instance Agda.Syntax.Internal.TermSize Agda.Syntax.Internal.Level
instance Agda.Syntax.Internal.TermSize Agda.Syntax.Internal.PlusLevel
instance Agda.Syntax.Internal.TermSize a => Agda.Syntax.Internal.TermSize (Agda.Syntax.Internal.Substitution' a)
instance Agda.Syntax.Internal.Suggest GHC.Base.String
instance Agda.Syntax.Internal.Suggest (Agda.Syntax.Internal.Abs b)
instance Agda.Syntax.Internal.Suggest Agda.Syntax.Abstract.Name.Name
instance Agda.Syntax.Internal.Suggest Agda.Syntax.Internal.Term
instance Agda.Syntax.Internal.SgTel (Agda.Syntax.Common.ArgName, Agda.Syntax.Internal.Dom Agda.Syntax.Internal.Type)
instance Agda.Syntax.Internal.SgTel (Agda.Syntax.Internal.Dom (Agda.Syntax.Common.ArgName, Agda.Syntax.Internal.Type))
instance Agda.Syntax.Internal.SgTel (Agda.Syntax.Internal.Dom Agda.Syntax.Internal.Type)
instance Agda.Syntax.Internal.TelToArgs Agda.Syntax.Internal.ListTel
instance Agda.Syntax.Internal.TelToArgs Agda.Syntax.Internal.Telescope
instance Agda.Syntax.Position.KillRange Agda.Syntax.Internal.Substitution
instance Agda.Utils.Null.Null (Agda.Syntax.Internal.Substitution' a)
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Internal.Substitution' a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Internal.Substitution' a)
instance Agda.Syntax.Internal.PatternVars (Agda.Syntax.Common.Arg (Agda.Syntax.Internal.Pattern' a))
instance Agda.Syntax.Internal.PatternVars (Agda.Syntax.Common.NamedArg (Agda.Syntax.Internal.Pattern' a))
instance Agda.Syntax.Internal.PatternVars a => Agda.Syntax.Internal.PatternVars [a]
instance Agda.Syntax.Position.HasRange Agda.Syntax.Internal.Clause
instance Agda.Utils.Null.Null Agda.Syntax.Internal.Clause
instance Agda.Syntax.Position.KillRange Agda.Syntax.Internal.Clause
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Internal.Clause
instance Control.DeepSeq.NFData Agda.Syntax.Internal.Clause
instance Agda.Syntax.Abstract.Name.IsProjP (Agda.Syntax.Internal.Pattern' a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Syntax.Internal.Pattern' a)
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Internal.Pattern' a)
instance Control.DeepSeq.NFData x => Control.DeepSeq.NFData (Agda.Syntax.Internal.Pattern' x)
instance Agda.Syntax.Position.KillRange Agda.Syntax.Internal.ConPatternInfo
instance Control.DeepSeq.NFData Agda.Syntax.Internal.ConPatternInfo
instance Agda.Syntax.Position.KillRange Agda.Syntax.Internal.DBPatVar
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Internal.DBPatVar
instance Control.DeepSeq.NFData Agda.Syntax.Internal.DBPatVar
instance Agda.Syntax.Position.KillRange Agda.Syntax.Internal.PatternInfo
instance Control.DeepSeq.NFData Agda.Syntax.Internal.PatternInfo
instance Agda.Syntax.Position.KillRange Agda.Syntax.Internal.PatOrigin
instance Control.DeepSeq.NFData Agda.Syntax.Internal.PatOrigin
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Syntax.Internal.Blocked a)
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Internal.Blocked a)
instance Agda.Syntax.Position.KillRange Agda.Syntax.Internal.PlusLevel
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Internal.PlusLevel
instance Control.DeepSeq.NFData Agda.Syntax.Internal.PlusLevel
instance Agda.Syntax.Internal.LensSort Agda.Syntax.Internal.Sort
instance Agda.Syntax.Internal.LensSort (Agda.Syntax.Internal.Type' a)
instance Agda.Syntax.Internal.LensSort a => Agda.Syntax.Internal.LensSort (Agda.Syntax.Internal.Dom a)
instance Agda.Syntax.Internal.LensSort a => Agda.Syntax.Internal.LensSort (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Position.KillRange Agda.Syntax.Internal.Term
instance Agda.Syntax.Position.KillRange Agda.Syntax.Internal.Level
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Syntax.Internal.Type' a)
instance Agda.Syntax.Position.KillRange Agda.Syntax.Internal.Sort
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Internal.Term
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Internal.Tele (Agda.Syntax.Internal.Dom a))
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Internal.Level
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Internal.Sort
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Internal.Type
instance Control.DeepSeq.NFData Agda.Syntax.Internal.Term
instance Control.DeepSeq.NFData Agda.Syntax.Internal.Type
instance Control.DeepSeq.NFData Agda.Syntax.Internal.Sort
instance Control.DeepSeq.NFData Agda.Syntax.Internal.Level
instance Control.DeepSeq.NFData e => Control.DeepSeq.NFData (Agda.Syntax.Internal.Dom e)
instance Agda.Utils.Functor.Decoration (Agda.Syntax.Internal.Type'' t)
instance Agda.Utils.Null.Null (Agda.Syntax.Internal.Tele a)
instance Agda.Utils.Size.Sized (Agda.Syntax.Internal.Tele a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Syntax.Internal.Tele a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Internal.Tele a)
instance Agda.Utils.Functor.Decoration Agda.Syntax.Internal.Abs
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Internal.Abs a)
instance Agda.Utils.Size.Sized a => Agda.Utils.Size.Sized (Agda.Syntax.Internal.Abs a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Syntax.Internal.Abs a)
instance Agda.Syntax.Common.Pretty.Pretty t => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Internal.Abs t)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Internal.Abs a)
instance Agda.Syntax.Position.SetRange Agda.Syntax.Internal.ConHead
instance Agda.Syntax.Internal.LensConName Agda.Syntax.Internal.ConHead
instance GHC.Classes.Eq Agda.Syntax.Internal.ConHead
instance GHC.Classes.Ord Agda.Syntax.Internal.ConHead
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Internal.ConHead
instance Agda.Syntax.Position.HasRange Agda.Syntax.Internal.ConHead
instance Agda.Syntax.Common.CopatternMatchingAllowed Agda.Syntax.Internal.ConHead
instance Agda.Syntax.Position.KillRange Agda.Syntax.Internal.ConHead
instance Control.DeepSeq.NFData Agda.Syntax.Internal.ConHead
instance Agda.Syntax.Common.PatternMatchingAllowed Agda.Syntax.Internal.DataOrRecord
instance Agda.Syntax.Common.CopatternMatchingAllowed Agda.Syntax.Internal.DataOrRecord
instance Agda.Syntax.Position.KillRange Agda.Syntax.Internal.DataOrRecord
instance Control.DeepSeq.NFData Agda.Syntax.Internal.DataOrRecord
instance Agda.Utils.Functor.Decoration (Agda.Syntax.Internal.Dom' t)
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange (Agda.Syntax.Internal.Dom' t a)
instance (Agda.Syntax.Position.KillRange t, Agda.Syntax.Position.KillRange a) => Agda.Syntax.Position.KillRange (Agda.Syntax.Internal.Dom' t a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Internal.Dom' t a)
instance Agda.Syntax.Common.LensNamed (Agda.Syntax.Internal.Dom' t e)
instance Agda.Syntax.Common.LensArgInfo (Agda.Syntax.Internal.Dom' t e)
instance Agda.Syntax.Common.LensLock (Agda.Syntax.Internal.Dom' t e)
instance Agda.Syntax.Common.LensHiding (Agda.Syntax.Internal.Dom' t e)
instance Agda.Syntax.Common.LensModality (Agda.Syntax.Internal.Dom' t e)
instance Agda.Syntax.Common.LensOrigin (Agda.Syntax.Internal.Dom' t e)
instance Agda.Syntax.Common.LensFreeVariables (Agda.Syntax.Internal.Dom' t e)
instance Agda.Syntax.Common.LensAnnotation (Agda.Syntax.Internal.Dom' t e)
instance Agda.Syntax.Common.LensRelevance (Agda.Syntax.Internal.Dom' t e)
instance Agda.Syntax.Common.LensQuantity (Agda.Syntax.Internal.Dom' t e)
instance Agda.Syntax.Common.LensCohesion (Agda.Syntax.Internal.Dom' t e)
instance (Agda.Syntax.Common.Pretty.Pretty t, Agda.Syntax.Common.Pretty.Pretty e) => Agda.Syntax.Common.Pretty.Pretty (Agda.Syntax.Internal.Dom' t e)
instance Control.DeepSeq.NFData Agda.Syntax.Internal.Univ.IsFibrant

module Agda.TypeChecking.Substitute.DeBruijn

-- | Things we can substitute for a variable. Needs to be able to represent
--   variables, e.g. for substituting under binders.
class DeBruijn a

-- | Produce a variable without name suggestion.
deBruijnVar :: DeBruijn a => Int -> a

-- | Produce a variable with name suggestion.
debruijnNamedVar :: DeBruijn a => String -> Int -> a

-- | Are we dealing with a variable? If yes, what is its index?
deBruijnView :: DeBruijn a => a -> Maybe Int
instance Agda.TypeChecking.Substitute.DeBruijn.DeBruijn Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Substitute.DeBruijn.DeBruijn Agda.Syntax.Internal.PlusLevel
instance Agda.TypeChecking.Substitute.DeBruijn.DeBruijn Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Substitute.DeBruijn.DeBruijn Agda.Syntax.Internal.DBPatVar
instance Agda.TypeChecking.Substitute.DeBruijn.DeBruijn a => Agda.TypeChecking.Substitute.DeBruijn.DeBruijn (Agda.Syntax.Common.Named_ a)


-- | Data structures for the type checker.
--   
--   Part of <a>Agda.TypeChecking.Monad.Base</a>, extracted to avoid import
--   cycles.
module Agda.TypeChecking.Monad.Base.Types

-- | The <tt>Context</tt> is a stack of <a>ContextEntry</a>s.
type Context = [ContextEntry]
type ContextEntry = Dom (Name, Type)


-- | Syntax of size expressions and constraints.
module Agda.TypeChecking.SizedTypes.Syntax

-- | Constant finite sizes <tt>n &gt;= 0</tt>.
newtype Offset
O :: Int -> Offset

-- | Fixed size variables <tt>i</tt>.
newtype Rigid
RigidId :: String -> Rigid
[rigidId] :: Rigid -> String

-- | Size meta variables <tt>X</tt> to solve for.
newtype Flex
FlexId :: String -> Flex
[flexId] :: Flex -> String

-- | Size expressions appearing in constraints.
data SizeExpr' rigid flex

-- | Constant number <tt>n</tt>.
Const :: Offset -> SizeExpr' rigid flex
[offset] :: SizeExpr' rigid flex -> Offset

-- | Variable plus offset <tt>i + n</tt>.
Rigid :: rigid -> Offset -> SizeExpr' rigid flex
[rigid] :: SizeExpr' rigid flex -> rigid
[offset] :: SizeExpr' rigid flex -> Offset

-- | Infinity <tt>∞</tt>.
Infty :: SizeExpr' rigid flex

-- | Meta variable <tt>X + n</tt>.
Flex :: flex -> Offset -> SizeExpr' rigid flex
[flex] :: SizeExpr' rigid flex -> flex
[offset] :: SizeExpr' rigid flex -> Offset
type SizeExpr = SizeExpr' Rigid Flex

-- | Comparison operator, e.g. for size expression.
data Cmp

-- | <tt>&lt;</tt>.
Lt :: Cmp

-- | <tt>≤</tt>.
Le :: Cmp

-- | Constraint: an inequation between size expressions, e.g. <tt>X &lt;
--   ∞</tt> or <tt>i + 3 ≤ j</tt>.
data Constraint' rigid flex
Constraint :: SizeExpr' rigid flex -> Cmp -> SizeExpr' rigid flex -> Constraint' rigid flex
[leftExpr] :: Constraint' rigid flex -> SizeExpr' rigid flex
[cmp] :: Constraint' rigid flex -> Cmp
[rightExpr] :: Constraint' rigid flex -> SizeExpr' rigid flex
type Constraint = Constraint' Rigid Flex

-- | What type of solution are we looking for?
data Polarity
Least :: Polarity
Greatest :: Polarity

-- | Assigning a polarity to a flexible variable.
data PolarityAssignment flex
PolarityAssignment :: Polarity -> flex -> PolarityAssignment flex

-- | Type of solution wanted for each flexible.
type Polarities flex = Map flex Polarity
emptyPolarities :: Polarities flex
polaritiesFromAssignments :: Ord flex => [PolarityAssignment flex] -> Polarities flex

-- | Default polarity is <a>Least</a>.
getPolarity :: Ord flex => Polarities flex -> flex -> Polarity

-- | Partial substitution from flexible variables to size expression.
newtype Solution rigid flex
Solution :: Map flex (SizeExpr' rigid flex) -> Solution rigid flex
[theSolution] :: Solution rigid flex -> Map flex (SizeExpr' rigid flex)
emptySolution :: Solution r f

-- | Executing a substitution.
class Substitute r f a
subst :: Substitute r f a => Solution r f -> a -> a
type CTrans r f = Constraint' r f -> Maybe [Constraint' r f]

-- | Returns <a>Nothing</a> if the constraint is contradictory.
simplify1 :: (Pretty f, Pretty r, Eq r) => CTrans r f -> CTrans r f

-- | <a>Le</a> acts as <a>True</a>, <a>Lt</a> as <a>False</a>.
ifLe :: Cmp -> a -> a -> a

-- | Interpret <a>Cmp</a> as relation on <a>Offset</a>.
compareOffset :: Offset -> Cmp -> Offset -> Bool

-- | Offsets <tt>+ n</tt> must be non-negative
class ValidOffset a
validOffset :: ValidOffset a => a -> Bool

-- | Make offsets non-negative by rounding up.
class TruncateOffset a
truncateOffset :: TruncateOffset a => a -> a

-- | The rigid variables contained in a pice of syntax.
class Ord (RigidOf a) => Rigids a where {
    type RigidOf a;
}
rigids :: Rigids a => a -> Set (RigidOf a)

-- | The flexibe variables contained in a pice of syntax.
class Ord (FlexOf a) => Flexs a where {
    type FlexOf a;
}
flexs :: Flexs a => a -> Set (FlexOf a)

-- | Identifiers for rigid variables.
data NamedRigid
NamedRigid :: String -> Int -> NamedRigid

-- | Name for printing in debug messages.
[rigidName] :: NamedRigid -> String

-- | De Bruijn index.
[rigidIndex] :: NamedRigid -> Int

-- | Size metas in size expressions.
data SizeMeta
SizeMeta :: MetaId -> [Int] -> SizeMeta
[sizeMetaId] :: SizeMeta -> MetaId

-- | De Bruijn indices.
[sizeMetaArgs] :: SizeMeta -> [Int]

-- | Size expression with de Bruijn indices.
type DBSizeExpr = SizeExpr' NamedRigid SizeMeta
type SizeConstraint = Constraint' NamedRigid SizeMeta

-- | Size constraint with de Bruijn indices.
data HypSizeConstraint
HypSizeConstraint :: Context -> [Nat] -> [SizeConstraint] -> SizeConstraint -> HypSizeConstraint
[sizeContext] :: HypSizeConstraint -> Context

-- | DeBruijn indices
[sizeHypIds] :: HypSizeConstraint -> [Nat]

-- | Living in <tt>Context</tt>.
[sizeHypotheses] :: HypSizeConstraint -> [SizeConstraint]

-- | Living in <tt>Context</tt>.
[sizeConstraint] :: HypSizeConstraint -> SizeConstraint
instance GHC.Enum.Enum Agda.TypeChecking.SizedTypes.Syntax.Offset
instance GHC.Num.Num Agda.TypeChecking.SizedTypes.Syntax.Offset
instance GHC.Generics.Generic Agda.TypeChecking.SizedTypes.Syntax.Offset
instance GHC.Classes.Ord Agda.TypeChecking.SizedTypes.Syntax.Offset
instance GHC.Classes.Eq Agda.TypeChecking.SizedTypes.Syntax.Offset
instance GHC.Classes.Ord Agda.TypeChecking.SizedTypes.Syntax.Rigid
instance GHC.Classes.Eq Agda.TypeChecking.SizedTypes.Syntax.Rigid
instance GHC.Classes.Ord Agda.TypeChecking.SizedTypes.Syntax.Flex
instance GHC.Classes.Eq Agda.TypeChecking.SizedTypes.Syntax.Flex
instance Data.Traversable.Traversable (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' rigid)
instance Data.Foldable.Foldable (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' rigid)
instance GHC.Base.Functor (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' rigid)
instance GHC.Generics.Generic (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' rigid flex)
instance (GHC.Classes.Ord rigid, GHC.Classes.Ord flex) => GHC.Classes.Ord (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' rigid flex)
instance (GHC.Classes.Eq rigid, GHC.Classes.Eq flex) => GHC.Classes.Eq (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' rigid flex)
instance (GHC.Show.Show rigid, GHC.Show.Show flex) => GHC.Show.Show (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' rigid flex)
instance GHC.Enum.Enum Agda.TypeChecking.SizedTypes.Syntax.Cmp
instance GHC.Enum.Bounded Agda.TypeChecking.SizedTypes.Syntax.Cmp
instance GHC.Generics.Generic Agda.TypeChecking.SizedTypes.Syntax.Cmp
instance GHC.Classes.Eq Agda.TypeChecking.SizedTypes.Syntax.Cmp
instance GHC.Show.Show Agda.TypeChecking.SizedTypes.Syntax.Cmp
instance Data.Traversable.Traversable (Agda.TypeChecking.SizedTypes.Syntax.Constraint' rigid)
instance Data.Foldable.Foldable (Agda.TypeChecking.SizedTypes.Syntax.Constraint' rigid)
instance GHC.Base.Functor (Agda.TypeChecking.SizedTypes.Syntax.Constraint' rigid)
instance GHC.Generics.Generic (Agda.TypeChecking.SizedTypes.Syntax.Constraint' rigid flex)
instance (GHC.Show.Show rigid, GHC.Show.Show flex) => GHC.Show.Show (Agda.TypeChecking.SizedTypes.Syntax.Constraint' rigid flex)
instance GHC.Classes.Ord Agda.TypeChecking.SizedTypes.Syntax.Polarity
instance GHC.Classes.Eq Agda.TypeChecking.SizedTypes.Syntax.Polarity
instance Agda.Utils.Null.Null (Agda.TypeChecking.SizedTypes.Syntax.Solution rigid flex)
instance (GHC.Show.Show flex, GHC.Show.Show rigid) => GHC.Show.Show (Agda.TypeChecking.SizedTypes.Syntax.Solution rigid flex)
instance GHC.Generics.Generic Agda.TypeChecking.SizedTypes.Syntax.NamedRigid
instance GHC.Show.Show Agda.TypeChecking.SizedTypes.Syntax.NamedRigid
instance GHC.Generics.Generic Agda.TypeChecking.SizedTypes.Syntax.SizeMeta
instance GHC.Show.Show Agda.TypeChecking.SizedTypes.Syntax.SizeMeta
instance GHC.Generics.Generic Agda.TypeChecking.SizedTypes.Syntax.HypSizeConstraint
instance GHC.Show.Show Agda.TypeChecking.SizedTypes.Syntax.HypSizeConstraint
instance Agda.TypeChecking.SizedTypes.Syntax.Flexs Agda.TypeChecking.SizedTypes.Syntax.HypSizeConstraint
instance Control.DeepSeq.NFData Agda.TypeChecking.SizedTypes.Syntax.HypSizeConstraint
instance Control.DeepSeq.NFData Agda.TypeChecking.SizedTypes.Syntax.SizeMeta
instance GHC.Classes.Eq Agda.TypeChecking.SizedTypes.Syntax.SizeMeta
instance GHC.Classes.Ord Agda.TypeChecking.SizedTypes.Syntax.SizeMeta
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.SizedTypes.Syntax.SizeMeta
instance Control.DeepSeq.NFData Agda.TypeChecking.SizedTypes.Syntax.NamedRigid
instance GHC.Classes.Eq Agda.TypeChecking.SizedTypes.Syntax.NamedRigid
instance GHC.Classes.Ord Agda.TypeChecking.SizedTypes.Syntax.NamedRigid
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.SizedTypes.Syntax.NamedRigid
instance Agda.TypeChecking.SizedTypes.Utils.Plus Agda.TypeChecking.SizedTypes.Syntax.NamedRigid GHC.Types.Int Agda.TypeChecking.SizedTypes.Syntax.NamedRigid
instance Agda.TypeChecking.SizedTypes.Syntax.Flexs a => Agda.TypeChecking.SizedTypes.Syntax.Flexs [a]
instance GHC.Classes.Ord flex => Agda.TypeChecking.SizedTypes.Syntax.Flexs (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' rigid flex)
instance GHC.Classes.Ord flex => Agda.TypeChecking.SizedTypes.Syntax.Flexs (Agda.TypeChecking.SizedTypes.Syntax.Constraint' rigid flex)
instance Agda.TypeChecking.SizedTypes.Syntax.Rigids a => Agda.TypeChecking.SizedTypes.Syntax.Rigids [a]
instance GHC.Classes.Ord r => Agda.TypeChecking.SizedTypes.Syntax.Rigids (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' r f)
instance GHC.Classes.Ord r => Agda.TypeChecking.SizedTypes.Syntax.Rigids (Agda.TypeChecking.SizedTypes.Syntax.Constraint' r f)
instance Agda.TypeChecking.SizedTypes.Syntax.TruncateOffset Agda.TypeChecking.SizedTypes.Syntax.Offset
instance Agda.TypeChecking.SizedTypes.Syntax.TruncateOffset (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' r f)
instance Agda.TypeChecking.SizedTypes.Syntax.ValidOffset Agda.TypeChecking.SizedTypes.Syntax.Offset
instance Agda.TypeChecking.SizedTypes.Syntax.ValidOffset (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' r f)
instance GHC.Classes.Ord f => Agda.TypeChecking.SizedTypes.Syntax.Substitute r f (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' r f)
instance GHC.Classes.Ord f => Agda.TypeChecking.SizedTypes.Syntax.Substitute r f (Agda.TypeChecking.SizedTypes.Syntax.Constraint' r f)
instance Agda.TypeChecking.SizedTypes.Syntax.Substitute r f a => Agda.TypeChecking.SizedTypes.Syntax.Substitute r f [a]
instance Agda.TypeChecking.SizedTypes.Syntax.Substitute r f a => Agda.TypeChecking.SizedTypes.Syntax.Substitute r f (Data.Map.Internal.Map k a)
instance GHC.Classes.Ord f => Agda.TypeChecking.SizedTypes.Syntax.Substitute r f (Agda.TypeChecking.SizedTypes.Syntax.Solution r f)
instance (Agda.Syntax.Common.Pretty.Pretty r, Agda.Syntax.Common.Pretty.Pretty f) => Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.SizedTypes.Syntax.Solution r f)
instance Agda.Syntax.Common.Pretty.Pretty flex => Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.SizedTypes.Syntax.PolarityAssignment flex)
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.SizedTypes.Syntax.Polarity
instance (Control.DeepSeq.NFData r, Control.DeepSeq.NFData f) => Control.DeepSeq.NFData (Agda.TypeChecking.SizedTypes.Syntax.Constraint' r f)
instance (Agda.Syntax.Common.Pretty.Pretty r, Agda.Syntax.Common.Pretty.Pretty f) => Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.SizedTypes.Syntax.Constraint' r f)
instance Control.DeepSeq.NFData Agda.TypeChecking.SizedTypes.Syntax.Cmp
instance Agda.TypeChecking.SizedTypes.Utils.Dioid Agda.TypeChecking.SizedTypes.Syntax.Cmp
instance GHC.Classes.Ord Agda.TypeChecking.SizedTypes.Syntax.Cmp
instance Agda.TypeChecking.SizedTypes.Utils.MeetSemiLattice Agda.TypeChecking.SizedTypes.Syntax.Cmp
instance Agda.TypeChecking.SizedTypes.Utils.Top Agda.TypeChecking.SizedTypes.Syntax.Cmp
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.SizedTypes.Syntax.Cmp
instance (Control.DeepSeq.NFData r, Control.DeepSeq.NFData f) => Control.DeepSeq.NFData (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' r f)
instance Agda.TypeChecking.SizedTypes.Utils.Plus (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' r f) Agda.TypeChecking.SizedTypes.Syntax.Offset (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' r f)
instance (Agda.Syntax.Common.Pretty.Pretty r, Agda.Syntax.Common.Pretty.Pretty f) => Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' r f)
instance GHC.Show.Show Agda.TypeChecking.SizedTypes.Syntax.Flex
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.SizedTypes.Syntax.Flex
instance GHC.Show.Show Agda.TypeChecking.SizedTypes.Syntax.Rigid
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.SizedTypes.Syntax.Rigid
instance Control.DeepSeq.NFData Agda.TypeChecking.SizedTypes.Syntax.Offset
instance GHC.Show.Show Agda.TypeChecking.SizedTypes.Syntax.Offset
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.SizedTypes.Syntax.Offset
instance Agda.TypeChecking.SizedTypes.Utils.MeetSemiLattice Agda.TypeChecking.SizedTypes.Syntax.Offset
instance Agda.TypeChecking.SizedTypes.Utils.Plus Agda.TypeChecking.SizedTypes.Syntax.Offset Agda.TypeChecking.SizedTypes.Syntax.Offset Agda.TypeChecking.SizedTypes.Syntax.Offset


-- | Precompute free variables in a term (and store in <a>ArgInfo</a>).
module Agda.TypeChecking.Free.Precompute
class PrecomputeFreeVars a
precomputeFreeVars :: PrecomputeFreeVars a => a -> FV a
precomputedFreeVars :: PrecomputeFreeVars a => a -> IntSet
precomputeFreeVars_ :: PrecomputeFreeVars a => a -> a
instance Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars a => Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars a => Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars (Agda.Syntax.Internal.Dom a)
instance Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars a => Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars (Agda.Syntax.Internal.Abs a)
instance Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars Agda.Syntax.Internal.PlusLevel
instance Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars Agda.Syntax.Internal.Type
instance Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars a => Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars a => Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars [a]
instance Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars a => Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars (GHC.Maybe.Maybe a)
instance (Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars a, Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars b) => Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars (a, b)


-- | Computing the free variables of a term lazily.
--   
--   We implement a reduce (traversal into monoid) over internal syntax for
--   a generic collection (monoid with singletons). This should allow a
--   more efficient test for the presence of a particular variable.
--   
--   Worst-case complexity does not change (i.e. the case when a variable
--   does not occur), but best case-complexity does matter. For instance,
--   see <a>mkAbs</a>: each time we construct a dependent function type, we
--   check whether it is actually dependent.
--   
--   The distinction between rigid and strongly rigid occurrences comes
--   from: Jason C. Reed, PhD thesis, 2009, page 96 (see also his LFMTP
--   2009 paper)
--   
--   The main idea is that x = t(x) is unsolvable if x occurs strongly
--   rigidly in t. It might have a solution if the occurrence is not
--   strongly rigid, e.g.
--   
--   x = f -&gt; suc (f (x ( y -&gt; k))) has x = f -&gt; suc (f (suc k))
--   
--   <ul>
--   <li><i>Jason C. Reed, PhD thesis, page 106</i></li>
--   </ul>
--   
--   Under coinductive constructors, occurrences are never strongly rigid.
--   Also, function types and lambdas do not establish strong rigidity.
--   Only inductive constructors do so. (See issue 1271).
--   
--   For further reading on semirings and semimodules for variable
--   occurrence, see e.g. Conor McBrides "I got plenty of nuttin'"
--   (Wadlerfest 2016). There, he treats the "quantity" dimension of
--   variable occurrences.
--   
--   The semiring has an additive operation for combining occurrences of
--   subterms, and a multiplicative operation of representing function
--   composition. E.g. if variable <tt>x</tt> appears <tt>o</tt> in term
--   <tt>u</tt>, but <tt>u</tt> appears in context <tt>q</tt> in term
--   <tt>t</tt> then occurrence of variable <tt>x</tt> coming from
--   <tt>u</tt> is accounted for as <tt>q o</tt> in <tt>t</tt>.
--   
--   Consider example <tt>(λ{ x → (x,x)}) y</tt>:
--   
--   <ul>
--   <li>Variable <tt>x</tt> occurs once unguarded in <tt>x</tt>.</li>
--   <li>It occurs twice unguarded in the aggregation <tt>x</tt>
--   <tt>x</tt></li>
--   <li>Inductive constructor <tt>,</tt> turns this into two strictly
--   rigid occurrences.</li>
--   </ul>
--   
--   If <tt>,</tt> is a record constructor, then we stay unguarded.
--   
--   <ul>
--   <li>The function <tt>({λ x → (x,x)})</tt> provides a context for
--   variable <tt>y</tt>. This context can be described as weakly rigid
--   with quantity two.</li>
--   <li>The final occurrence of <tt>y</tt> is obtained as composing the
--   context with the occurrence of <tt>y</tt> in itself (which is the unit
--   for composition). Thus, <tt>y</tt> occurs weakly rigid with quantity
--   two.</li>
--   </ul>
--   
--   It is not a given that the context can be described in the same way as
--   the variable occurrence. However, for quantity it is the case and we
--   obtain a semiring of occurrences with 0, 1, and even ω, which is an
--   absorptive element for addition.
module Agda.TypeChecking.Free.Lazy

-- | A set of meta variables. Forms a monoid under union.
newtype MetaSet
MetaSet :: HashSet MetaId -> MetaSet
[theMetaSet] :: MetaSet -> HashSet MetaId
insertMetaSet :: MetaId -> MetaSet -> MetaSet
foldrMetaSet :: (MetaId -> a -> a) -> a -> MetaSet -> a
metaSetToBlocker :: MetaSet -> Blocker

-- | Depending on the surrounding context of a variable, it's occurrence
--   can be classified as flexible or rigid, with finer distinctions.
--   
--   The constructors are listed in increasing order (wrt. information
--   content).
data FlexRig' a

-- | In arguments of metas. The set of metas is used by
--   '<a>NonLinMatch'</a> to generate the right blocking information. The
--   semantics is that the status of a variable occurrence may change if
--   one of the metas in the set gets solved. We may say the occurrence is
--   tainted by the meta variables in the set.
Flexible :: a -> FlexRig' a

-- | In arguments to variables and definitions.
WeaklyRigid :: FlexRig' a

-- | In top position, or only under inductive record constructors (unit).
Unguarded :: FlexRig' a

-- | Under at least one and only inductive constructors.
StronglyRigid :: FlexRig' a
type FlexRig = FlexRig' MetaSet
class LensFlexRig o a | o -> a
lensFlexRig :: LensFlexRig o a => Lens' o (FlexRig' a)
isFlexible :: LensFlexRig o a => o -> Bool
isUnguarded :: LensFlexRig o a => o -> Bool
isWeaklyRigid :: LensFlexRig o a => o -> Bool
isStronglyRigid :: LensFlexRig o a => o -> Bool

-- | <a>FlexRig</a> aggregation (additive operation of the semiring). For
--   combining occurrences of the same variable in subterms. This is a
--   refinement of the <a>max</a> operation for <a>FlexRig</a> which would
--   work if <a>Flexible</a> did not have the <a>MetaSet</a> as an
--   argument. Now, to aggregate two <a>Flexible</a> occurrences, we union
--   the involved <a>MetaSet</a>s.
addFlexRig :: Semigroup a => FlexRig' a -> FlexRig' a -> FlexRig' a

-- | Unit for <a>addFlexRig</a>.
zeroFlexRig :: Monoid a => FlexRig' a

-- | Absorptive for <a>addFlexRig</a>.
omegaFlexRig :: FlexRig' a

-- | <a>FlexRig</a> composition (multiplicative operation of the semiring).
--   For accumulating the context of a variable.
--   
--   <a>Flexible</a> is dominant. Once we are under a meta, we are flexible
--   regardless what else comes. We taint all variable occurrences under a
--   meta by this meta.
--   
--   <a>WeaklyRigid</a> is next in strength. Destroys strong rigidity.
--   
--   <a>StronglyRigid</a> is still dominant over <a>Unguarded</a>.
--   
--   <a>Unguarded</a> is the unit. It is the top (identity) context.
composeFlexRig :: Semigroup a => FlexRig' a -> FlexRig' a -> FlexRig' a

-- | Unit for <a>composeFlexRig</a>.
oneFlexRig :: FlexRig' a

-- | Occurrence of free variables is classified by several dimensions.
--   Currently, we have <a>FlexRig</a> and <a>Modality</a>.
data VarOcc' a
VarOcc :: FlexRig' a -> Modality -> VarOcc' a
[varFlexRig] :: VarOcc' a -> FlexRig' a
[varModality] :: VarOcc' a -> Modality
type VarOcc = VarOcc' MetaSet

-- | The absorptive element of variable occurrence under aggregation:
--   strongly rigid, relevant.
topVarOcc :: VarOcc' a

-- | First argument is the outer occurrence (context) and second is the
--   inner. This multiplicative operation is to modify an occurrence under
--   a context.
composeVarOcc :: Semigroup a => VarOcc' a -> VarOcc' a -> VarOcc' a
oneVarOcc :: VarOcc' a

-- | Any representation <tt>c</tt> of a set of variables need to be able to
--   be modified by a variable occurrence. This is to ensure that free
--   variable analysis is compositional. For instance, it should be
--   possible to compute `fv (v [u/x])` from `fv v` and `fv u`.
--   
--   In algebraic terminology, a variable set <tt>a</tt> needs to be
--   (almost) a left semimodule to the semiring <a>VarOcc'</a>.
class (Singleton MetaId a, Semigroup a, Monoid a, Semigroup c, Monoid c) => IsVarSet a c | c -> a

-- | Laws * Respects monoid operations: ``` withVarOcc o mempty == mempty
--   withVarOcc o (x &lt;&gt; y) == withVarOcc o x &lt;&gt; withVarOcc o y
--   ``` * Respects VarOcc composition: ``` withVarOcc oneVarOcc = id
--   withVarOcc (composeVarOcc o1 o2) = withVarOcc o1 . withVarOcc o2 ``` *
--   Respects VarOcc aggregation: ``` withVarOcc (o1 &lt;&gt; o2) x =
--   withVarOcc o1 x &lt;&gt; withVarOcc o2 x ``` Since the corresponding
--   unit law may fail, ``` withVarOcc mempty x = mempty ``` it is not
--   quite a semimodule.
withVarOcc :: IsVarSet a c => VarOcc' a -> c -> c

-- | Representation of a variable set as map from de Bruijn indices to
--   <a>VarOcc'</a>.
type TheVarMap' a = IntMap (VarOcc' a)
newtype VarMap' a
VarMap :: TheVarMap' a -> VarMap' a
[theVarMap] :: VarMap' a -> TheVarMap' a
type TheVarMap = TheVarMap' MetaSet
type VarMap = VarMap' MetaSet
mapVarMap :: (TheVarMap' a -> TheVarMap' b) -> VarMap' a -> VarMap' b
lookupVarMap :: Variable -> VarMap' a -> Maybe (VarOcc' a)

-- | Keep track of <a>FlexRig</a> for every variable, but forget the
--   involved meta vars.
type TheFlexRigMap = IntMap (FlexRig' ())
newtype FlexRigMap
FlexRigMap :: TheFlexRigMap -> FlexRigMap
[theFlexRigMap] :: FlexRigMap -> TheFlexRigMap
mapFlexRigMap :: (TheFlexRigMap -> TheFlexRigMap) -> FlexRigMap -> FlexRigMap

-- | Where should we skip sorts in free variable analysis?
data IgnoreSorts

-- | Do not skip.
IgnoreNot :: IgnoreSorts

-- | Skip when annotation to a type.
IgnoreInAnnotations :: IgnoreSorts

-- | Skip unconditionally.
IgnoreAll :: IgnoreSorts

-- | The current context.
data FreeEnv' a b c
FreeEnv :: !b -> !FlexRig' a -> !Modality -> (Maybe Variable -> c) -> FreeEnv' a b c

-- | Additional context, e.g., whether to ignore free variables in sorts.
[feExtra] :: FreeEnv' a b c -> !b

-- | Are we flexible or rigid?
[feFlexRig] :: FreeEnv' a b c -> !FlexRig' a

-- | What is the current relevance and quantity?
[feModality] :: FreeEnv' a b c -> !Modality

-- | Method to return a single variable.
[feSingleton] :: FreeEnv' a b c -> Maybe Variable -> c
type Variable = Int
type SingleVar c = Variable -> c
type FreeEnv c = FreeEnv' MetaSet IgnoreSorts c

-- | Ignore free variables in sorts.
feIgnoreSorts :: FreeEnv' a IgnoreSorts c -> IgnoreSorts

-- | The initial context.
initFreeEnv :: Monoid c => b -> SingleVar c -> FreeEnv' a b c
type FreeT a b m c = ReaderT (FreeEnv' a b c) m c
type FreeM a c = Reader (FreeEnv' a IgnoreSorts c) c

-- | Run function for FreeM.
runFreeM :: IsVarSet a c => SingleVar c -> IgnoreSorts -> FreeM a c -> c

-- | Base case: a variable.
variable :: (Monad m, IsVarSet a c) => Int -> FreeT a b m c

-- | Subtract, but return Nothing if result is negative.
subVar :: Int -> Maybe Variable -> Maybe Variable

-- | Going under a binder.
underBinder :: MonadReader (FreeEnv' a b c) m => m z -> m z

-- | Going under <tt>n</tt> binders.
underBinder' :: MonadReader (FreeEnv' a b c) m => Nat -> m z -> m z

-- | Changing the <a>Modality</a>.
underModality :: (MonadReader r m, LensModality r, LensModality o) => o -> m z -> m z

-- | Changing the <a>Relevance</a>.
underRelevance :: (MonadReader r m, LensRelevance r, LensRelevance o) => o -> m z -> m z

-- | In the given computation the <a>Quantity</a> is locally scaled using
--   the <a>Quantity</a> of the first argument.
underQuantity :: (MonadReader r m, LensQuantity r, LensQuantity o) => o -> m a -> m a

-- | Changing the <a>FlexRig</a> context.
underFlexRig :: (MonadReader r m, LensFlexRig r a, Semigroup a, LensFlexRig o a) => o -> m z -> m z

-- | What happens to the variables occurring under a constructor?
underConstructor :: (MonadReader r m, LensFlexRig r a, Semigroup a) => ConHead -> Elims -> m z -> m z

-- | Gather free variables in a collection.
class Free t
freeVars' :: (Free t, IsVarSet a c) => t -> FreeM a c
freeVars' :: (Free t, t ~ f b, Foldable f, Free b) => IsVarSet a c => t -> FreeM a c
instance GHC.Base.Monoid Agda.TypeChecking.Free.Lazy.MetaSet
instance GHC.Base.Semigroup Agda.TypeChecking.Free.Lazy.MetaSet
instance Agda.Utils.Null.Null Agda.TypeChecking.Free.Lazy.MetaSet
instance GHC.Show.Show Agda.TypeChecking.Free.Lazy.MetaSet
instance GHC.Classes.Eq Agda.TypeChecking.Free.Lazy.MetaSet
instance Data.Foldable.Foldable Agda.TypeChecking.Free.Lazy.FlexRig'
instance GHC.Base.Functor Agda.TypeChecking.Free.Lazy.FlexRig'
instance GHC.Show.Show a => GHC.Show.Show (Agda.TypeChecking.Free.Lazy.FlexRig' a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.TypeChecking.Free.Lazy.FlexRig' a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.TypeChecking.Free.Lazy.VarOcc' a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.TypeChecking.Free.Lazy.VarMap' a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.TypeChecking.Free.Lazy.VarMap' a)
instance GHC.Show.Show Agda.TypeChecking.Free.Lazy.IgnoreSorts
instance GHC.Classes.Eq Agda.TypeChecking.Free.Lazy.IgnoreSorts
instance Agda.Utils.Singleton.Singleton (Agda.TypeChecking.Free.Lazy.Variable, Agda.TypeChecking.Free.Lazy.FlexRig' ()) Agda.TypeChecking.Free.Lazy.FlexRigMap
instance GHC.Show.Show Agda.TypeChecking.Free.Lazy.FlexRigMap
instance Agda.TypeChecking.Free.Lazy.Free Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Free.Lazy.Free t => Agda.TypeChecking.Free.Lazy.Free (Agda.Syntax.Internal.Type' t)
instance Agda.TypeChecking.Free.Lazy.Free Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Free.Lazy.Free Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Free.Lazy.Free t => Agda.TypeChecking.Free.Lazy.Free (Agda.Syntax.Internal.PlusLevel' t)
instance Agda.TypeChecking.Free.Lazy.Free t => Agda.TypeChecking.Free.Lazy.Free [t]
instance Agda.TypeChecking.Free.Lazy.Free t => Agda.TypeChecking.Free.Lazy.Free (GHC.Maybe.Maybe t)
instance Agda.TypeChecking.Free.Lazy.Free t => Agda.TypeChecking.Free.Lazy.Free (Agda.Syntax.Common.WithHiding t)
instance Agda.TypeChecking.Free.Lazy.Free t => Agda.TypeChecking.Free.Lazy.Free (Agda.Syntax.Common.Named nm t)
instance (Agda.TypeChecking.Free.Lazy.Free t, Agda.TypeChecking.Free.Lazy.Free u) => Agda.TypeChecking.Free.Lazy.Free (t, u)
instance (Agda.TypeChecking.Free.Lazy.Free t, Agda.TypeChecking.Free.Lazy.Free u, Agda.TypeChecking.Free.Lazy.Free v) => Agda.TypeChecking.Free.Lazy.Free (t, u, v)
instance Agda.TypeChecking.Free.Lazy.Free t => Agda.TypeChecking.Free.Lazy.Free (Agda.Syntax.Internal.Elim.Elim' t)
instance Agda.TypeChecking.Free.Lazy.Free t => Agda.TypeChecking.Free.Lazy.Free (Agda.Syntax.Common.Arg t)
instance Agda.TypeChecking.Free.Lazy.Free t => Agda.TypeChecking.Free.Lazy.Free (Agda.Syntax.Internal.Dom t)
instance Agda.TypeChecking.Free.Lazy.Free t => Agda.TypeChecking.Free.Lazy.Free (Agda.Syntax.Internal.Abs t)
instance Agda.TypeChecking.Free.Lazy.Free t => Agda.TypeChecking.Free.Lazy.Free (Agda.Syntax.Internal.Tele t)
instance Agda.TypeChecking.Free.Lazy.Free Agda.Syntax.Internal.Clause
instance Agda.TypeChecking.Free.Lazy.Free Agda.Syntax.Internal.EqualityView
instance (GHC.Base.Functor m, GHC.Base.Applicative m, GHC.Base.Monad m, GHC.Base.Semigroup c, GHC.Base.Monoid c) => GHC.Base.Monoid (Agda.TypeChecking.Free.Lazy.FreeT a b m c)
instance GHC.Base.Semigroup Agda.TypeChecking.Free.Lazy.FlexRigMap
instance GHC.Base.Monoid Agda.TypeChecking.Free.Lazy.FlexRigMap
instance Agda.TypeChecking.Free.Lazy.IsVarSet () Agda.TypeChecking.Free.Lazy.FlexRigMap
instance Agda.TypeChecking.Free.Lazy.LensFlexRig (Agda.TypeChecking.Free.Lazy.FreeEnv' a b c) a
instance Agda.Syntax.Common.LensModality (Agda.TypeChecking.Free.Lazy.FreeEnv' a b c)
instance Agda.Syntax.Common.LensRelevance (Agda.TypeChecking.Free.Lazy.FreeEnv' a b c)
instance Agda.Syntax.Common.LensQuantity (Agda.TypeChecking.Free.Lazy.FreeEnv' a b c)
instance Agda.Utils.Singleton.Singleton Agda.TypeChecking.Free.Lazy.Variable (Agda.TypeChecking.Free.Lazy.VarMap' a)
instance GHC.Base.Semigroup a => GHC.Base.Semigroup (Agda.TypeChecking.Free.Lazy.VarMap' a)
instance GHC.Base.Semigroup a => GHC.Base.Monoid (Agda.TypeChecking.Free.Lazy.VarMap' a)
instance (Agda.Utils.Singleton.Singleton Agda.Syntax.Common.MetaId a, GHC.Base.Semigroup a, GHC.Base.Monoid a) => Agda.TypeChecking.Free.Lazy.IsVarSet a (Agda.TypeChecking.Free.Lazy.VarMap' a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.TypeChecking.Free.Lazy.VarOcc' a)
instance Agda.Syntax.Common.LensModality (Agda.TypeChecking.Free.Lazy.VarOcc' a)
instance Agda.Syntax.Common.LensRelevance (Agda.TypeChecking.Free.Lazy.VarOcc' a)
instance Agda.Syntax.Common.LensQuantity (Agda.TypeChecking.Free.Lazy.VarOcc' a)
instance Agda.TypeChecking.Free.Lazy.LensFlexRig (Agda.TypeChecking.Free.Lazy.VarOcc' a) a
instance GHC.Base.Semigroup a => GHC.Base.Semigroup (Agda.TypeChecking.Free.Lazy.VarOcc' a)
instance (GHC.Base.Semigroup a, GHC.Base.Monoid a) => GHC.Base.Monoid (Agda.TypeChecking.Free.Lazy.VarOcc' a)
instance Agda.TypeChecking.Free.Lazy.LensFlexRig (Agda.TypeChecking.Free.Lazy.FlexRig' a) a
instance Agda.Utils.Singleton.Singleton Agda.Syntax.Common.MetaId Agda.TypeChecking.Free.Lazy.MetaSet
instance Agda.Utils.Singleton.Singleton Agda.Syntax.Common.MetaId ()

module Agda.TypeChecking.DiscrimTree.Types
data Key

-- | Rigid symbols (constructors, data types, record types, postulates)
--   identified by a QName.
RigidK :: {-# UNPACK #-} !QName -> {-# UNPACK #-} !Int -> Key

-- | Local variables.
LocalK :: {-# UNPACK #-} !Int -> {-# UNPACK #-} !Int -> Key

-- | Dependent function types. The domain will be represented accurately,
--   for the case of a genuine dependent function type, the codomain will
--   be a dummy.
PiK :: Key

-- | Constant lambdas.
ConstK :: Key

-- | Universes.
SortK :: Key

-- | Anything else.
FlexK :: Key

-- | A <a>Term</a>-indexed associative data structure supporting
--   <i>approximate</i> (conservative) lookup. Rather than using a
--   <tt>Trie</tt> keyed by <a>Key</a> directly, a <a>DiscrimTree</a> is
--   instead represented more like a <i>case</i> tree.
--   
--   This allows us to exploit the fact that instance selection often
--   focuses on a small part of the term: Only that critical chain is
--   represented in the tree. As an example, level parameters are unlikely
--   to contribute to narrowing a search problem, so it would be wasteful
--   to have an indirection in the tree for every <a>FlexK</a> standing for
--   a level parameter.
data DiscrimTree a

-- | The empty discrimination tree.
EmptyDT :: DiscrimTree a

-- | Succeed with a given set of values.
DoneDT :: Set a -> DiscrimTree a

-- | Do case analysis on a term. <a>CaseDT</a> is scoped in the same way as
--   fast case trees for the abstract machine: When matching actually
--   succeeds, the variable that was matched gets replaced by its arguments
--   directly in the context.
CaseDT :: {-# UNPACK #-} !Int -> Map Key (DiscrimTree a) -> DiscrimTree a -> DiscrimTree a

-- | Merge a pair of discrimination trees. This function tries to build the
--   minimal discrimination tree that yields the union of the inputs'
--   results, though it does so slightly naïvely, without considerable
--   optimisations (e.g. it does not turn single-alternative <a>CaseDT</a>s
--   into <a>DoneDT</a>s).
mergeDT :: Ord a => DiscrimTree a -> DiscrimTree a -> DiscrimTree a

-- | Construct the case tree corresponding to only performing proper
--   matches on the given key. In this context, a "proper match" is any
--   <a>Key</a> that is not <a>FlexK</a>.
singletonDT :: [Key] -> a -> DiscrimTree a
instance GHC.Generics.Generic Agda.TypeChecking.DiscrimTree.Types.Key
instance GHC.Classes.Ord Agda.TypeChecking.DiscrimTree.Types.Key
instance GHC.Classes.Eq Agda.TypeChecking.DiscrimTree.Types.Key
instance GHC.Show.Show Agda.TypeChecking.DiscrimTree.Types.Key
instance GHC.Show.Show a => GHC.Show.Show (Agda.TypeChecking.DiscrimTree.Types.DiscrimTree a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.TypeChecking.DiscrimTree.Types.DiscrimTree a)
instance GHC.Generics.Generic (Agda.TypeChecking.DiscrimTree.Types.DiscrimTree a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.TypeChecking.DiscrimTree.Types.DiscrimTree a)
instance (Agda.Syntax.Position.KillRange a, GHC.Classes.Ord a) => Agda.Syntax.Position.KillRange (Agda.TypeChecking.DiscrimTree.Types.DiscrimTree a)
instance Agda.Utils.Null.Null (Agda.TypeChecking.DiscrimTree.Types.DiscrimTree a)
instance GHC.Classes.Ord a => GHC.Base.Semigroup (Agda.TypeChecking.DiscrimTree.Types.DiscrimTree a)
instance GHC.Classes.Ord a => GHC.Base.Monoid (Agda.TypeChecking.DiscrimTree.Types.DiscrimTree a)
instance Control.DeepSeq.NFData Agda.TypeChecking.DiscrimTree.Types.Key

module Agda.Syntax.Reflected
type Args = [Arg Term]
data Elim' a
Apply :: Arg a -> Elim' a
type Elim = Elim' Term
type Elims = [Elim]
argsToElims :: Args -> Elims
data Abs a
Abs :: String -> a -> Abs a
data Term
Var :: Int -> Elims -> Term
Con :: QName -> Elims -> Term
Def :: QName -> Elims -> Term
Meta :: MetaId -> Elims -> Term
Lam :: Hiding -> Abs Term -> Term
ExtLam :: List1 Clause -> Elims -> Term
Pi :: Dom Type -> Abs Type -> Term
Sort :: Sort -> Term
Lit :: Literal -> Term
Unknown :: Term
type Type = Term
data Sort
SetS :: Term -> Sort
LitS :: Integer -> Sort
PropS :: Term -> Sort
PropLitS :: Integer -> Sort
InfS :: Integer -> Sort
UnknownS :: Sort
data Pattern
ConP :: QName -> [Arg Pattern] -> Pattern
DotP :: Term -> Pattern
VarP :: Int -> Pattern
LitP :: Literal -> Pattern
AbsurdP :: Int -> Pattern
ProjP :: QName -> Pattern
data Clause
Clause :: [(Text, Arg Type)] -> [Arg Pattern] -> Term -> Clause
[clauseTel] :: Clause -> [(Text, Arg Type)]
[clausePats] :: Clause -> [Arg Pattern]
[clauseRHS] :: Clause -> Term
AbsurdClause :: [(Text, Arg Type)] -> [Arg Pattern] -> Clause
[clauseTel] :: Clause -> [(Text, Arg Type)]
[clausePats] :: Clause -> [Arg Pattern]
data Definition
FunDef :: Type -> [Clause] -> Definition
DataDef :: Definition
RecordDef :: Definition
DataConstructor :: Definition
Axiom :: Definition
Primitive :: Definition
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Reflected.Elim' a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Reflected.Abs a)
instance GHC.Show.Show Agda.Syntax.Reflected.Sort
instance GHC.Show.Show Agda.Syntax.Reflected.Term
instance GHC.Show.Show Agda.Syntax.Reflected.Pattern
instance GHC.Show.Show Agda.Syntax.Reflected.Clause
instance GHC.Show.Show Agda.Syntax.Reflected.Definition

module Agda.Syntax.Internal.Pattern

-- | Translate the clause patterns to terms with free variables bound by
--   the clause telescope.
--   
--   Precondition: no projection patterns.
clauseArgs :: Clause -> Args

-- | Translate the clause patterns to an elimination spine with free
--   variables bound by the clause telescope.
clauseElims :: Clause -> Elims

-- | Arity of a function, computed from clauses.
class FunArity a
funArity :: FunArity a => a -> Int

-- | Label the pattern variables from left to right using one label for
--   each variable pattern and one for each dot pattern.
class LabelPatVars a b where {
    type PatVarLabel b;
}
labelPatVars :: LabelPatVars a b => a -> State [PatVarLabel b] b

-- | Intended, but unpractical due to the absence of type-level lambda, is:
--   <tt>labelPatVars :: f (Pattern' x) -&gt; State [i] (f (Pattern'
--   (i,x)))</tt>
unlabelPatVars :: LabelPatVars a b => b -> a
labelPatVars :: (LabelPatVars a b, Traversable f, LabelPatVars a' b', PatVarLabel b ~ PatVarLabel b', f a' ~ a, f b' ~ b) => a -> State [PatVarLabel b] b

-- | Intended, but unpractical due to the absence of type-level lambda, is:
--   <tt>labelPatVars :: f (Pattern' x) -&gt; State [i] (f (Pattern'
--   (i,x)))</tt>
unlabelPatVars :: (LabelPatVars a b, Traversable f, LabelPatVars a' b', f a' ~ a, f b' ~ b) => b -> a

-- | Augment pattern variables with their de Bruijn index.
numberPatVars :: (LabelPatVars a b, PatVarLabel b ~ Int) => Int -> Permutation -> a -> b
unnumberPatVars :: LabelPatVars a b => b -> a
dbPatPerm :: [NamedArg DeBruijnPattern] -> Maybe Permutation

-- | Computes the permutation from the clause telescope to the pattern
--   variables.
--   
--   Use as <tt>fromMaybe <b>IMPOSSIBLE</b> . dbPatPerm</tt> to crash in a
--   controlled way if a de Bruijn index is out of scope here.
--   
--   The first argument controls whether dot patterns counts as variables
--   or not.
dbPatPerm' :: Bool -> [NamedArg DeBruijnPattern] -> Maybe Permutation

-- | Computes the permutation from the clause telescope to the pattern
--   variables.
--   
--   Use as <tt>fromMaybe <b>IMPOSSIBLE</b> . clausePerm</tt> to crash in a
--   controlled way if a de Bruijn index is out of scope here.
clausePerm :: Clause -> Maybe Permutation

-- | Turn a pattern into a term. Projection patterns are turned into
--   projection eliminations, other patterns into apply elimination.
patternToElim :: Arg DeBruijnPattern -> Elim
patternsToElims :: [NamedArg DeBruijnPattern] -> [Elim]
patternToTerm :: DeBruijnPattern -> Term
class MapNamedArgPattern a p
mapNamedArgPattern :: MapNamedArgPattern a p => (NamedArg (Pattern' a) -> NamedArg (Pattern' a)) -> p -> p
mapNamedArgPattern :: (MapNamedArgPattern a p, Functor f, MapNamedArgPattern a p', p ~ f p') => (NamedArg (Pattern' a) -> NamedArg (Pattern' a)) -> p -> p

-- | Generic pattern traversal.
--   
--   Pre-applies a pattern modification, recurses, and post-applies another
--   one.
class PatternLike a b

-- | Fold pattern.
foldrPattern :: (PatternLike a b, Monoid m) => (Pattern' a -> m -> m) -> b -> m

-- | Fold pattern.
foldrPattern :: (PatternLike a b, Monoid m, Foldable f, PatternLike a p, f p ~ b) => (Pattern' a -> m -> m) -> b -> m

-- | Traverse pattern.
traversePatternM :: (PatternLike a b, Monad m) => (Pattern' a -> m (Pattern' a)) -> (Pattern' a -> m (Pattern' a)) -> b -> m b

-- | Traverse pattern.
traversePatternM :: (PatternLike a b, Traversable f, PatternLike a p, f p ~ b, Monad m) => (Pattern' a -> m (Pattern' a)) -> (Pattern' a -> m (Pattern' a)) -> b -> m b

-- | Compute from each subpattern a value and collect them all in a monoid.
foldPattern :: (PatternLike a b, Monoid m) => (Pattern' a -> m) -> b -> m

-- | Traverse pattern(s) with a modification before the recursive descent.
preTraversePatternM :: (PatternLike a b, Monad m) => (Pattern' a -> m (Pattern' a)) -> b -> m b

-- | Traverse pattern(s) with a modification after the recursive descent.
postTraversePatternM :: (PatternLike a b, Monad m) => (Pattern' a -> m (Pattern' a)) -> b -> m b
class CountPatternVars a
countPatternVars :: CountPatternVars a => a -> Int
countPatternVars :: (CountPatternVars a, Foldable f, CountPatternVars b, f b ~ a) => a -> Int
class PatternVarModalities p where {
    type PatVar p;
}

-- | Get the list of pattern variables annotated with modalities.
patternVarModalities :: PatternVarModalities p => p -> [(PatVar p, Modality)]
hasDefP :: [NamedArg DeBruijnPattern] -> Bool
instance Agda.Syntax.Internal.Pattern.PatternVarModalities a => Agda.Syntax.Internal.Pattern.PatternVarModalities [a]
instance Agda.Syntax.Internal.Pattern.PatternVarModalities a => Agda.Syntax.Internal.Pattern.PatternVarModalities (Agda.Syntax.Common.Named s a)
instance Agda.Syntax.Internal.Pattern.PatternVarModalities a => Agda.Syntax.Internal.Pattern.PatternVarModalities (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Internal.Pattern.PatternVarModalities (Agda.Syntax.Internal.Pattern' x)
instance Agda.Syntax.Internal.Pattern.CountPatternVars a => Agda.Syntax.Internal.Pattern.CountPatternVars [a]
instance Agda.Syntax.Internal.Pattern.CountPatternVars a => Agda.Syntax.Internal.Pattern.CountPatternVars (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Internal.Pattern.CountPatternVars a => Agda.Syntax.Internal.Pattern.CountPatternVars (Agda.Syntax.Common.Named x a)
instance Agda.Syntax.Internal.Pattern.CountPatternVars (Agda.Syntax.Internal.Pattern' x)
instance Agda.Syntax.Internal.Pattern.PatternLike a (Agda.Syntax.Internal.Pattern' a)
instance Agda.Syntax.Internal.Pattern.PatternLike a b => Agda.Syntax.Internal.Pattern.PatternLike a [b]
instance Agda.Syntax.Internal.Pattern.PatternLike a b => Agda.Syntax.Internal.Pattern.PatternLike a (Agda.Syntax.Common.Arg b)
instance Agda.Syntax.Internal.Pattern.PatternLike a b => Agda.Syntax.Internal.Pattern.PatternLike a (Agda.Syntax.Common.Named x b)
instance Agda.Syntax.Internal.Pattern.MapNamedArgPattern a (Agda.Syntax.Common.NamedArg (Agda.Syntax.Internal.Pattern' a))
instance Agda.Syntax.Internal.Pattern.MapNamedArgPattern a p => Agda.Syntax.Internal.Pattern.MapNamedArgPattern a [p]
instance Agda.Syntax.Internal.Pattern.LabelPatVars a b => Agda.Syntax.Internal.Pattern.LabelPatVars (Agda.Syntax.Common.Arg a) (Agda.Syntax.Common.Arg b)
instance Agda.Syntax.Internal.Pattern.LabelPatVars a b => Agda.Syntax.Internal.Pattern.LabelPatVars (Agda.Syntax.Common.Named x a) (Agda.Syntax.Common.Named x b)
instance Agda.Syntax.Internal.Pattern.LabelPatVars a b => Agda.Syntax.Internal.Pattern.LabelPatVars [a] [b]
instance Agda.Syntax.Internal.Pattern.LabelPatVars Agda.Syntax.Internal.Pattern Agda.Syntax.Internal.DeBruijnPattern
instance Agda.Syntax.Abstract.Name.IsProjP p => Agda.Syntax.Internal.Pattern.FunArity [p]
instance Agda.Syntax.Internal.Pattern.FunArity Agda.Syntax.Internal.Clause
instance Agda.Syntax.Internal.Pattern.FunArity [Agda.Syntax.Internal.Clause]


-- | Tree traversal for internal syntax.
module Agda.Syntax.Internal.Generic

-- | Generic term traversal.
--   
--   Note: ignores sorts in terms! (Does not traverse into or collect from
--   them.)
class TermLike a

-- | Generic traversal with post-traversal action. Ignores sorts.
traverseTermM :: (TermLike a, Monad m) => (Term -> m Term) -> a -> m a

-- | Generic traversal with post-traversal action. Ignores sorts.
traverseTermM :: (TermLike a, Monad m, Traversable f, TermLike b, f b ~ a) => (Term -> m Term) -> a -> m a

-- | Generic fold, ignoring sorts.
foldTerm :: (TermLike a, Monoid m) => (Term -> m) -> a -> m

-- | Generic fold, ignoring sorts.
foldTerm :: (TermLike a, Monoid m, Foldable f, TermLike b, f b ~ a) => (Term -> m) -> a -> m

-- | Put it in a monad to make it possible to do strictly.
copyTerm :: (TermLike a, Monad m) => a -> m a
instance Agda.Syntax.Internal.Generic.TermLike GHC.Types.Bool
instance Agda.Syntax.Internal.Generic.TermLike GHC.Types.Int
instance Agda.Syntax.Internal.Generic.TermLike GHC.Num.Integer.Integer
instance Agda.Syntax.Internal.Generic.TermLike GHC.Types.Char
instance Agda.Syntax.Internal.Generic.TermLike Agda.Syntax.Abstract.Name.QName
instance Agda.Syntax.Internal.Generic.TermLike a => Agda.Syntax.Internal.Generic.TermLike (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.Syntax.Internal.Generic.TermLike a => Agda.Syntax.Internal.Generic.TermLike (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Internal.Generic.TermLike a => Agda.Syntax.Internal.Generic.TermLike (Agda.Syntax.Internal.Dom a)
instance Agda.Syntax.Internal.Generic.TermLike a => Agda.Syntax.Internal.Generic.TermLike [a]
instance Agda.Syntax.Internal.Generic.TermLike a => Agda.Syntax.Internal.Generic.TermLike (GHC.Maybe.Maybe a)
instance Agda.Syntax.Internal.Generic.TermLike a => Agda.Syntax.Internal.Generic.TermLike (Agda.Syntax.Internal.Blocked a)
instance Agda.Syntax.Internal.Generic.TermLike a => Agda.Syntax.Internal.Generic.TermLike (Agda.Syntax.Internal.Abs a)
instance Agda.Syntax.Internal.Generic.TermLike a => Agda.Syntax.Internal.Generic.TermLike (Agda.Syntax.Internal.Tele a)
instance Agda.Syntax.Internal.Generic.TermLike a => Agda.Syntax.Internal.Generic.TermLike (Agda.Syntax.Common.WithHiding a)
instance (Agda.Syntax.Internal.Generic.TermLike a, Agda.Syntax.Internal.Generic.TermLike b) => Agda.Syntax.Internal.Generic.TermLike (a, b)
instance (Agda.Syntax.Internal.Generic.TermLike a, Agda.Syntax.Internal.Generic.TermLike b, Agda.Syntax.Internal.Generic.TermLike c) => Agda.Syntax.Internal.Generic.TermLike (a, b, c)
instance (Agda.Syntax.Internal.Generic.TermLike a, Agda.Syntax.Internal.Generic.TermLike b, Agda.Syntax.Internal.Generic.TermLike c, Agda.Syntax.Internal.Generic.TermLike d) => Agda.Syntax.Internal.Generic.TermLike (a, b, c, d)
instance Agda.Syntax.Internal.Generic.TermLike Agda.Syntax.Internal.Term
instance Agda.Syntax.Internal.Generic.TermLike Agda.Syntax.Internal.Level
instance Agda.Syntax.Internal.Generic.TermLike Agda.Syntax.Internal.PlusLevel
instance Agda.Syntax.Internal.Generic.TermLike Agda.Syntax.Internal.Type
instance Agda.Syntax.Internal.Generic.TermLike Agda.Syntax.Internal.Sort
instance Agda.Syntax.Internal.Generic.TermLike Agda.Syntax.Internal.EqualityView


-- | Case trees.
--   
--   After coverage checking, pattern matching is translated to case trees,
--   i.e., a tree of successive case splits on one variable at a time.
module Agda.TypeChecking.CompiledClause
data WithArity c
WithArity :: Int -> c -> WithArity c
[arity] :: WithArity c -> Int
[content] :: WithArity c -> c

-- | Branches in a case tree.
data Case c
Branches :: Bool -> Map QName (WithArity c) -> Maybe (ConHead, WithArity c) -> Map Literal c -> Maybe c -> Maybe Bool -> Bool -> Case c

-- | We are constructing a record here (copatterns). <a>conBranches</a>
--   lists projections.
[projPatterns] :: Case c -> Bool

-- | Map from constructor (or projection) names to their arity and the case
--   subtree. (Projections have arity 0.)
[conBranches] :: Case c -> Map QName (WithArity c)

-- | Eta-expand with the given (eta record) constructor. If this is
--   present, there should not be any conBranches or litBranches.
[etaBranch] :: Case c -> Maybe (ConHead, WithArity c)

-- | Map from literal to case subtree.
[litBranches] :: Case c -> Map Literal c

-- | (Possibly additional) catch-all clause.
[catchAllBranch] :: Case c -> Maybe c

-- | (if True) In case of non-canonical argument use catchAllBranch.
[fallThrough] :: Case c -> Maybe Bool

-- | Lazy pattern match. Requires single (non-copattern) branch with no lit
--   branches and no catch-all.
[lazyMatch] :: Case c -> Bool

-- | Case tree with bodies.
data CompiledClauses' a

-- | <tt>Case n bs</tt> stands for a match on the <tt>n</tt>-th argument
--   (counting from zero) with <tt>bs</tt> as the case branches. If the
--   <tt>n</tt>-th argument is a projection, we have only
--   <a>conBranches</a> with arity 0.
Case :: Arg Int -> Case (CompiledClauses' a) -> CompiledClauses' a

-- | <tt>Done xs b</tt> stands for the body <tt>b</tt> where the
--   <tt>xs</tt> contains hiding and name suggestions for the free
--   variables. This is needed to build lambdas on the right hand side for
--   partial applications which can still reduce.
Done :: [Arg ArgName] -> a -> CompiledClauses' a

-- | Absurd case. Add the free variables here as well so we can build
--   correct number of lambdas for strict backends. (#4280)
Fail :: [Arg ArgName] -> CompiledClauses' a
type CompiledClauses = CompiledClauses' Term
litCase :: Literal -> c -> Case c
conCase :: QName -> Bool -> WithArity c -> Case c
etaCase :: ConHead -> WithArity c -> Case c
projCase :: QName -> c -> Case c
catchAll :: c -> Case c

-- | Check that the requirements on lazy matching (single inductive case)
--   are met, and set lazy to False otherwise.
checkLazyMatch :: Case c -> Case c

-- | Check whether a case tree has a catch-all clause.
hasCatchAll :: CompiledClauses -> Bool

-- | Check whether a case tree has any projection patterns
hasProjectionPatterns :: CompiledClauses -> Bool
prettyMap_ :: (Pretty k, Pretty v) => Map k v -> [Doc]
instance GHC.Generics.Generic (Agda.TypeChecking.CompiledClause.WithArity c)
instance GHC.Show.Show c => GHC.Show.Show (Agda.TypeChecking.CompiledClause.WithArity c)
instance Data.Traversable.Traversable Agda.TypeChecking.CompiledClause.WithArity
instance Data.Foldable.Foldable Agda.TypeChecking.CompiledClause.WithArity
instance GHC.Base.Functor Agda.TypeChecking.CompiledClause.WithArity
instance GHC.Generics.Generic (Agda.TypeChecking.CompiledClause.Case c)
instance GHC.Show.Show c => GHC.Show.Show (Agda.TypeChecking.CompiledClause.Case c)
instance Data.Traversable.Traversable Agda.TypeChecking.CompiledClause.Case
instance Data.Foldable.Foldable Agda.TypeChecking.CompiledClause.Case
instance GHC.Base.Functor Agda.TypeChecking.CompiledClause.Case
instance GHC.Generics.Generic (Agda.TypeChecking.CompiledClause.CompiledClauses' a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.TypeChecking.CompiledClause.CompiledClauses' a)
instance Data.Foldable.Foldable Agda.TypeChecking.CompiledClause.CompiledClauses'
instance Data.Traversable.Traversable Agda.TypeChecking.CompiledClause.CompiledClauses'
instance GHC.Base.Functor Agda.TypeChecking.CompiledClause.CompiledClauses'
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.CompiledClause.CompiledClauses
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.CompiledClause.CompiledClauses
instance Agda.Syntax.Internal.Generic.TermLike a => Agda.Syntax.Internal.Generic.TermLike (Agda.TypeChecking.CompiledClause.CompiledClauses' a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.TypeChecking.CompiledClause.CompiledClauses' a)
instance GHC.Base.Semigroup m => GHC.Base.Semigroup (Agda.TypeChecking.CompiledClause.Case m)
instance (GHC.Base.Semigroup m, GHC.Base.Monoid m) => GHC.Base.Monoid (Agda.TypeChecking.CompiledClause.Case m)
instance Agda.Utils.Null.Null (Agda.TypeChecking.CompiledClause.Case m)
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.CompiledClause.Case a)
instance Agda.Syntax.Position.KillRange c => Agda.Syntax.Position.KillRange (Agda.TypeChecking.CompiledClause.Case c)
instance Agda.Syntax.Internal.Generic.TermLike a => Agda.Syntax.Internal.Generic.TermLike (Agda.TypeChecking.CompiledClause.Case a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.TypeChecking.CompiledClause.Case a)
instance GHC.Base.Semigroup c => GHC.Base.Semigroup (Agda.TypeChecking.CompiledClause.WithArity c)
instance (GHC.Base.Semigroup c, GHC.Base.Monoid c) => GHC.Base.Monoid (Agda.TypeChecking.CompiledClause.WithArity c)
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.CompiledClause.WithArity a)
instance Agda.Syntax.Position.KillRange c => Agda.Syntax.Position.KillRange (Agda.TypeChecking.CompiledClause.WithArity c)
instance Agda.Syntax.Internal.Generic.TermLike a => Agda.Syntax.Internal.Generic.TermLike (Agda.TypeChecking.CompiledClause.WithArity a)
instance Control.DeepSeq.NFData c => Control.DeepSeq.NFData (Agda.TypeChecking.CompiledClause.WithArity c)

module Agda.Syntax.Internal.MetaVars

-- | Returns every meta-variable occurrence in the given type, except for
--   those in sort annotations on types.
class AllMetas t
allMetas :: (AllMetas t, Monoid m) => (MetaId -> m) -> t -> m
allMetas :: (AllMetas t, TermLike t, Monoid m) => (MetaId -> m) -> t -> m
allMetas' :: (TermLike a, Monoid m) => (MetaId -> m) -> a -> m

-- | Returns <a>allMetas</a> in a list. <tt>allMetasList = allMetas
--   (:[])</tt>.
--   
--   Note: this resulting list is computed via difference lists. Thus, use
--   this function if you actually need the whole list of metas. Otherwise,
--   use <a>allMetas</a> with a suitable monoid.
allMetasList :: AllMetas a => a -> [MetaId]

-- | <a>True</a> if thing contains no metas. <tt>noMetas = null .
--   allMetasList</tt>.
noMetas :: AllMetas a => a -> Bool

-- | Returns the first meta it find in the thing, if any. <tt>firstMeta ==
--   listToMaybe . allMetasList</tt>.
firstMeta :: AllMetas a => a -> Maybe MetaId

-- | A blocker that unblocks if any of the metas in a term are solved.
unblockOnAnyMetaIn :: AllMetas t => t -> Blocker

-- | A blocker that unblocks if any of the metas in a term are solved.
unblockOnAllMetasIn :: AllMetas t => t -> Blocker
instance Agda.Syntax.Internal.MetaVars.AllMetas Agda.Syntax.Internal.Term
instance Agda.Syntax.Internal.MetaVars.AllMetas Agda.Syntax.Internal.Type
instance Agda.Syntax.Internal.Generic.TermLike a => Agda.Syntax.Internal.MetaVars.AllMetas (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.Syntax.Internal.Generic.TermLike a => Agda.Syntax.Internal.MetaVars.AllMetas (Agda.Syntax.Internal.Tele a)
instance (Agda.Syntax.Internal.MetaVars.AllMetas a, Agda.Syntax.Internal.MetaVars.AllMetas b) => Agda.Syntax.Internal.MetaVars.AllMetas (Agda.Syntax.Internal.Dom' a b)
instance Agda.Syntax.Internal.MetaVars.AllMetas Agda.Syntax.Internal.Sort
instance Agda.Syntax.Internal.MetaVars.AllMetas Agda.Syntax.Internal.Level
instance Agda.Syntax.Internal.MetaVars.AllMetas Agda.Syntax.Internal.PlusLevel
instance Agda.Syntax.Internal.MetaVars.AllMetas GHC.Base.String
instance (Agda.Syntax.Internal.MetaVars.AllMetas a, Agda.Syntax.Internal.MetaVars.AllMetas b) => Agda.Syntax.Internal.MetaVars.AllMetas (a, b)
instance (Agda.Syntax.Internal.MetaVars.AllMetas a, Agda.Syntax.Internal.MetaVars.AllMetas b, Agda.Syntax.Internal.MetaVars.AllMetas c) => Agda.Syntax.Internal.MetaVars.AllMetas (a, b, c)
instance (Agda.Syntax.Internal.MetaVars.AllMetas a, Agda.Syntax.Internal.MetaVars.AllMetas b, Agda.Syntax.Internal.MetaVars.AllMetas c, Agda.Syntax.Internal.MetaVars.AllMetas d) => Agda.Syntax.Internal.MetaVars.AllMetas (a, b, c, d)
instance Agda.Syntax.Internal.MetaVars.AllMetas a => Agda.Syntax.Internal.MetaVars.AllMetas [a]
instance Agda.Syntax.Internal.MetaVars.AllMetas a => Agda.Syntax.Internal.MetaVars.AllMetas (GHC.Maybe.Maybe a)
instance Agda.Syntax.Internal.MetaVars.AllMetas a => Agda.Syntax.Internal.MetaVars.AllMetas (Agda.Syntax.Common.Arg a)


-- | Extract used definitions from terms.
module Agda.Syntax.Internal.Defs

-- | <tt>getDefs' lookup emb a</tt> extracts all used definitions
--   (functions, data/record types) from <tt>a</tt>, embedded into a monoid
--   via <tt>emb</tt>. Instantiations of meta variables are obtained via
--   <tt>lookup</tt>.
--   
--   Typical monoid instances would be <tt>[QName]</tt> or <tt>Set
--   QName</tt>. Note that <tt>emb</tt> can also choose to discard a used
--   definition by mapping to the unit of the monoid.
getDefs' :: (GetDefs a, Monoid b) => (MetaId -> Maybe Term) -> (QName -> b) -> a -> b

-- | Inputs to and outputs of <tt>getDefs'</tt> are organized as a monad.
type GetDefsM b = ReaderT (GetDefsEnv b) (Writer b)
data GetDefsEnv b
GetDefsEnv :: (MetaId -> Maybe Term) -> (QName -> b) -> GetDefsEnv b
[lookupMeta] :: GetDefsEnv b -> MetaId -> Maybe Term
[embDef] :: GetDefsEnv b -> QName -> b

-- | What it takes to get the used definitions.
class Monad m => MonadGetDefs m
doDef :: MonadGetDefs m => QName -> m ()
doMeta :: MonadGetDefs m => MetaId -> m ()

-- | Getting the used definitions.
--   
--   Note: in contrast to <a>foldTerm</a> <tt>getDefs</tt> also collects
--   from sorts in terms. Thus, this is not an instance of
--   <tt>foldTerm</tt>.
class GetDefs a
getDefs :: (GetDefs a, MonadGetDefs m) => a -> m ()
getDefs :: (GetDefs a, MonadGetDefs m, Foldable f, GetDefs b, f b ~ a) => a -> m ()
instance GHC.Base.Monoid b => Agda.Syntax.Internal.Defs.MonadGetDefs (Agda.Syntax.Internal.Defs.GetDefsM b)
instance Agda.Syntax.Internal.Defs.GetDefs Agda.Syntax.Internal.Clause
instance Agda.Syntax.Internal.Defs.GetDefs Agda.Syntax.Internal.Term
instance Agda.Syntax.Internal.Defs.GetDefs Agda.Syntax.Common.MetaId
instance Agda.Syntax.Internal.Defs.GetDefs Agda.Syntax.Internal.Type
instance Agda.Syntax.Internal.Defs.GetDefs Agda.Syntax.Internal.Sort
instance Agda.Syntax.Internal.Defs.GetDefs Agda.Syntax.Internal.Level
instance Agda.Syntax.Internal.Defs.GetDefs Agda.Syntax.Internal.PlusLevel
instance Agda.Syntax.Internal.Defs.GetDefs a => Agda.Syntax.Internal.Defs.GetDefs (GHC.Maybe.Maybe a)
instance Agda.Syntax.Internal.Defs.GetDefs a => Agda.Syntax.Internal.Defs.GetDefs [a]
instance Agda.Syntax.Internal.Defs.GetDefs a => Agda.Syntax.Internal.Defs.GetDefs (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.Syntax.Internal.Defs.GetDefs a => Agda.Syntax.Internal.Defs.GetDefs (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Internal.Defs.GetDefs a => Agda.Syntax.Internal.Defs.GetDefs (Agda.Syntax.Internal.Dom a)
instance Agda.Syntax.Internal.Defs.GetDefs a => Agda.Syntax.Internal.Defs.GetDefs (Agda.Syntax.Internal.Abs a)
instance (Agda.Syntax.Internal.Defs.GetDefs a, Agda.Syntax.Internal.Defs.GetDefs b) => Agda.Syntax.Internal.Defs.GetDefs (a, b)
instance Agda.Syntax.Internal.Defs.GetDefs Agda.Syntax.Internal.Telescope
instance Agda.Syntax.Internal.Defs.GetDefs GHC.Base.String


-- | Tools for patterns in concrete syntax.
module Agda.Syntax.Concrete.Pattern

-- | Check for ellipsis <tt>...</tt>.
class IsEllipsis a
isEllipsis :: IsEllipsis a => a -> Bool

-- | Has the lhs an occurrence of the ellipsis <tt>...</tt>?
class HasEllipsis a
hasEllipsis :: HasEllipsis a => a -> Bool

-- | Check for with-pattern <tt>| p</tt>.
class IsWithP p
isWithP :: IsWithP p => p -> Maybe p
isWithP :: (IsWithP p, IsWithP q, Decoration f, f q ~ p) => p -> Maybe p

-- | The next patterns are ...
--   
--   (This view discards <tt>PatInfo</tt>.)
data LHSPatternView

-- | Application patterns (non-empty list).
LHSAppP :: [NamedArg Pattern] -> LHSPatternView

-- | With patterns (non-empty list). These patterns are not prefixed with
--   <a>WithP</a>.
LHSWithP :: [Pattern] -> LHSPatternView

-- | Construct the <a>LHSPatternView</a> of the given list (if not empty).
--   
--   Return the view and the remaining patterns.
lhsPatternView :: [NamedArg Pattern] -> Maybe (LHSPatternView, [NamedArg Pattern])

-- | Add applicative patterns (non-projection / non-with patterns) to the
--   right.
lhsCoreApp :: LHSCore -> [NamedArg Pattern] -> LHSCore

-- | Add with-patterns to the right.
lhsCoreWith :: LHSCore -> [Pattern] -> LHSCore

-- | Append patterns to <a>LHSCore</a>, separating with patterns from the
--   rest.
lhsCoreAddSpine :: LHSCore -> [NamedArg Pattern] -> LHSCore

-- | Modify the <a>Pattern</a> component in <a>LHS</a>.
mapLhsOriginalPattern :: (Pattern -> Pattern) -> LHS -> LHS

-- | Effectfully modify the <a>Pattern</a> component in <a>LHS</a>.
mapLhsOriginalPatternM :: (Functor m, Applicative m) => (Pattern -> m Pattern) -> LHS -> m LHS

-- | Does the LHS contain projection patterns?
hasCopatterns :: LHSCore -> Bool

-- | Generic pattern traversal.
--   
--   See <a>APatternLike</a>.
class CPatternLike p

-- | Fold pattern.
foldrCPattern :: (CPatternLike p, Monoid m) => (Pattern -> m -> m) -> p -> m

-- | Fold pattern.
foldrCPattern :: (CPatternLike p, Monoid m, Foldable f, CPatternLike q, f q ~ p) => (Pattern -> m -> m) -> p -> m

-- | Traverse pattern with option of post-traversal modification.
traverseCPatternA :: (CPatternLike p, Applicative m, Functor m) => (Pattern -> m Pattern -> m Pattern) -> p -> m p

-- | Traverse pattern with option of post-traversal modification.
traverseCPatternA :: (CPatternLike p, Traversable f, CPatternLike q, f q ~ p, Applicative m, Functor m) => (Pattern -> m Pattern -> m Pattern) -> p -> m p

-- | Traverse pattern.
traverseCPatternM :: (CPatternLike p, Monad m) => (Pattern -> m Pattern) -> (Pattern -> m Pattern) -> p -> m p

-- | Traverse pattern.
traverseCPatternM :: (CPatternLike p, Traversable f, CPatternLike q, f q ~ p, Monad m) => (Pattern -> m Pattern) -> (Pattern -> m Pattern) -> p -> m p

-- | Compute a value from each subpattern and collect all values in a
--   monoid.
foldCPattern :: (CPatternLike p, Monoid m) => (Pattern -> m) -> p -> m

-- | Traverse pattern(s) with a modification before the recursive descent.
preTraverseCPatternM :: (CPatternLike p, Monad m) => (Pattern -> m Pattern) -> p -> m p

-- | Traverse pattern(s) with a modification after the recursive descent.
postTraverseCPatternM :: (CPatternLike p, Monad m) => (Pattern -> m Pattern) -> p -> m p

-- | Map pattern(s) with a modification after the recursive descent.
mapCPattern :: CPatternLike p => (Pattern -> Pattern) -> p -> p

-- | Get all the identifiers in a pattern in left-to-right order.
--   
--   Implemented using difference lists.
patternQNames :: CPatternLike p => p -> [QName]

-- | Get all the identifiers in a pattern in left-to-right order.
patternNames :: Pattern -> [Name]

-- | Does the pattern contain a with-pattern? (Shortcutting.)
hasWithPatterns :: CPatternLike p => p -> Bool

-- | Is <a>WithP</a>?
isWithPattern :: Pattern -> Bool

-- | Count the number of with-subpatterns in a pattern?
numberOfWithPatterns :: CPatternLike p => p -> Int

-- | Compute the context in which the ellipsis occurs, if at all. If there
--   are several occurrences, this is an error. This only counts ellipsis
--   that haven't already been expanded.
hasEllipsis' :: CPatternLike p => p -> AffineHole Pattern p
reintroduceEllipsis :: ExpandedEllipsis -> Pattern -> Pattern
splitEllipsis :: IsWithP p => Int -> [p] -> ([p], [p])

-- | View a pattern <tt>p</tt> as a list <tt>p0 .. pn</tt> where
--   <tt>p0</tt> is the identifier (in most cases a constructor).
--   
--   Pattern needs to be parsed already (operators resolved).
patternAppView :: Pattern -> List1 (NamedArg Pattern)
instance Agda.Syntax.Concrete.Pattern.CPatternLike Agda.Syntax.Concrete.Pattern
instance (Agda.Syntax.Concrete.Pattern.CPatternLike a, Agda.Syntax.Concrete.Pattern.CPatternLike b) => Agda.Syntax.Concrete.Pattern.CPatternLike (a, b)
instance Agda.Syntax.Concrete.Pattern.CPatternLike p => Agda.Syntax.Concrete.Pattern.CPatternLike (Agda.Syntax.Common.Arg p)
instance Agda.Syntax.Concrete.Pattern.CPatternLike p => Agda.Syntax.Concrete.Pattern.CPatternLike (Agda.Syntax.Common.Named n p)
instance Agda.Syntax.Concrete.Pattern.CPatternLike p => Agda.Syntax.Concrete.Pattern.CPatternLike [p]
instance Agda.Syntax.Concrete.Pattern.CPatternLike p => Agda.Syntax.Concrete.Pattern.CPatternLike (Agda.Utils.List1.List1 p)
instance Agda.Syntax.Concrete.Pattern.CPatternLike p => Agda.Syntax.Concrete.Pattern.CPatternLike (Agda.Utils.List2.List2 p)
instance Agda.Syntax.Concrete.Pattern.CPatternLike p => Agda.Syntax.Concrete.Pattern.CPatternLike (GHC.Maybe.Maybe p)
instance Agda.Syntax.Concrete.Pattern.CPatternLike p => Agda.Syntax.Concrete.Pattern.CPatternLike (Agda.Syntax.Concrete.FieldAssignment' p)
instance Agda.Syntax.Concrete.Pattern.IsWithP Agda.Syntax.Concrete.Pattern
instance Agda.Syntax.Concrete.Pattern.IsWithP p => Agda.Syntax.Concrete.Pattern.IsWithP (Agda.Syntax.Common.Arg p)
instance Agda.Syntax.Concrete.Pattern.IsWithP p => Agda.Syntax.Concrete.Pattern.IsWithP (Agda.Syntax.Common.Named n p)
instance Agda.Syntax.Concrete.Pattern.HasEllipsis Agda.Syntax.Concrete.Pattern
instance Agda.Syntax.Concrete.Pattern.HasEllipsis Agda.Syntax.Concrete.LHS
instance Agda.Syntax.Concrete.Pattern.IsEllipsis Agda.Syntax.Concrete.Pattern

module Agda.Syntax.Concrete.Operators.Parser
placeholder :: PositionInName -> Parser e (MaybePlaceholder e)
maybePlaceholder :: Maybe PositionInName -> Parser e e -> Parser e (MaybePlaceholder e)
satNoPlaceholder :: (e -> Maybe a) -> Parser e a
data ExprView e
LocalV :: QName -> ExprView e
WildV :: e -> ExprView e
OtherV :: e -> ExprView e
AppV :: e -> NamedArg e -> ExprView e

-- | The <a>QName</a> is possibly ambiguous, but it must correspond to one
--   of the names in the set.
OpAppV :: QName -> Set Name -> OpAppArgs' e -> ExprView e
HiddenArgV :: Named_ e -> ExprView e
InstanceArgV :: Named_ e -> ExprView e
LamV :: List1 LamBinding -> e -> ExprView e
ParenV :: e -> ExprView e
class HasRange e => IsExpr e
exprView :: IsExpr e => e -> ExprView e
unExprView :: IsExpr e => ExprView e -> e
patternView :: IsExpr e => e -> Maybe Pattern

-- | Should sections be parsed?
data ParseSections
ParseSections :: ParseSections
DoNotParseSections :: ParseSections

-- | Runs a parser. If sections should be parsed, then identifiers with at
--   least two name parts are split up into multiple tokens, using
--   <a>PositionInName</a> to record the tokens' original positions within
--   their respective identifiers.
parse :: IsExpr e => (ParseSections, Parser e a) -> [e] -> [a]

-- | Parse a specific identifier as a NamePart
partP :: IsExpr e => [Name] -> RawName -> Parser e Range

-- | Parses a split-up, unqualified name consisting of at least two name
--   parts.
--   
--   The parser does not check that underscores and other name parts
--   alternate. The range of the resulting name is the range of the first
--   name part that is not an underscore.
atLeastTwoParts :: IsExpr e => Parser e Name

-- | Parses a potentially pattern-matching binder
patternBinder :: IsExpr e => Parser e Binder

-- | Used to define the return type of <a>opP</a>.
type family OperatorType (k :: NotationKind) (e :: Type) :: Type

-- | A singleton type for <a>NotationKind</a> (except for the constructor
--   <a>NoNotation</a>).
data NK (k :: NotationKind) :: Type
[In] :: NK 'InfixNotation
[Pre] :: NK 'PrefixNotation
[Post] :: NK 'PostfixNotation
[Non] :: NK 'NonfixNotation

-- | Parse the "operator part" of the given notation.
--   
--   Normal holes (but not binders) at the beginning and end are ignored.
--   
--   If the notation does not contain any binders, then a section notation
--   is allowed.
opP :: forall e k. IsExpr e => ParseSections -> Parser e e -> NewNotation -> NK k -> Parser e (OperatorType k e)
argsP :: IsExpr e => Parser e e -> Parser e [NamedArg e]
appP :: IsExpr e => Parser e e -> Parser e [NamedArg e] -> Parser e e
atomP :: IsExpr e => (QName -> Bool) -> Parser e e
instance GHC.Show.Show Agda.Syntax.Concrete.Operators.Parser.ParseSections
instance GHC.Classes.Eq Agda.Syntax.Concrete.Operators.Parser.ParseSections
instance Agda.Syntax.Concrete.Operators.Parser.IsExpr e => Agda.Syntax.Position.HasRange (Agda.Syntax.Concrete.Operators.Parser.ExprView e)
instance Agda.Syntax.Concrete.Operators.Parser.IsExpr Agda.Syntax.Concrete.Expr
instance Agda.Syntax.Concrete.Operators.Parser.IsExpr Agda.Syntax.Concrete.Pattern


-- | Generic traversal and reduce for concrete syntax, in the style of
--   <a>Agda.Syntax.Internal.Generic</a>.
--   
--   However, here we use the terminology of <a>Traversable</a>.
module Agda.Syntax.Concrete.Generic

-- | Generic traversals for concrete expressions.
--   
--   Note: does not go into patterns!
class ExprLike a

-- | This corresponds to <a>map</a>.
mapExpr :: ExprLike a => (Expr -> Expr) -> a -> a

-- | This corresponds to <a>foldMap</a>.
foldExpr :: (ExprLike a, Monoid m) => (Expr -> m) -> a -> m

-- | This corresponds to <a>mapM</a>.
traverseExpr :: (ExprLike a, Monad m) => (Expr -> m Expr) -> a -> m a

-- | This corresponds to <a>map</a>.
mapExpr :: (ExprLike a, Functor t, ExprLike b, t b ~ a) => (Expr -> Expr) -> a -> a

-- | This corresponds to <a>foldMap</a>.
foldExpr :: (ExprLike a, Monoid m, Foldable t, ExprLike b, t b ~ a) => (Expr -> m) -> a -> m

-- | This corresponds to <a>mapM</a>.
traverseExpr :: (ExprLike a, Monad m, Traversable t, ExprLike b, t b ~ a) => (Expr -> m Expr) -> a -> m a
class FoldDecl a

-- | Collect declarations and subdeclarations, transitively. Prefix-order
--   tree traversal.
foldDecl :: (FoldDecl a, Monoid m) => (Declaration -> m) -> a -> m

-- | Collect declarations and subdeclarations, transitively. Prefix-order
--   tree traversal.
foldDecl :: (FoldDecl a, Monoid m, Foldable t, FoldDecl b, t b ~ a) => (Declaration -> m) -> a -> m
class TraverseDecl a

-- | Update declarations and their subdeclarations. Prefix-order traversal:
--   traverses subdeclarations of updated declaration.
preTraverseDecl :: (TraverseDecl a, Monad m) => (Declaration -> m Declaration) -> a -> m a

-- | Update declarations and their subdeclarations. Prefix-order traversal:
--   traverses subdeclarations of updated declaration.
preTraverseDecl :: (TraverseDecl a, Monad m, Traversable t, TraverseDecl b, t b ~ a) => (Declaration -> m Declaration) -> a -> m a
instance Agda.Syntax.Concrete.Generic.TraverseDecl a => Agda.Syntax.Concrete.Generic.TraverseDecl [a]
instance Agda.Syntax.Concrete.Generic.TraverseDecl a => Agda.Syntax.Concrete.Generic.TraverseDecl (Agda.Utils.List1.List1 a)
instance Agda.Syntax.Concrete.Generic.TraverseDecl a => Agda.Syntax.Concrete.Generic.TraverseDecl (Agda.Utils.List2.List2 a)
instance Agda.Syntax.Concrete.Generic.TraverseDecl a => Agda.Syntax.Concrete.Generic.TraverseDecl (Agda.Syntax.Concrete.WhereClause' a)
instance Agda.Syntax.Concrete.Generic.TraverseDecl Agda.Syntax.Concrete.Declaration
instance Agda.Syntax.Concrete.Generic.FoldDecl a => Agda.Syntax.Concrete.Generic.FoldDecl [a]
instance Agda.Syntax.Concrete.Generic.FoldDecl a => Agda.Syntax.Concrete.Generic.FoldDecl (Agda.Utils.List1.List1 a)
instance Agda.Syntax.Concrete.Generic.FoldDecl a => Agda.Syntax.Concrete.Generic.FoldDecl (Agda.Utils.List2.List2 a)
instance Agda.Syntax.Concrete.Generic.FoldDecl a => Agda.Syntax.Concrete.Generic.FoldDecl (Agda.Syntax.Concrete.WhereClause' a)
instance Agda.Syntax.Concrete.Generic.FoldDecl Agda.Syntax.Concrete.Declaration
instance Agda.Syntax.Concrete.Generic.ExprLike ()
instance Agda.Syntax.Concrete.Generic.ExprLike Agda.Syntax.Concrete.Name.Name
instance Agda.Syntax.Concrete.Generic.ExprLike Agda.Syntax.Concrete.Name.QName
instance Agda.Syntax.Concrete.Generic.ExprLike GHC.Types.Bool
instance Agda.Syntax.Concrete.Generic.ExprLike a => Agda.Syntax.Concrete.Generic.ExprLike [a]
instance Agda.Syntax.Concrete.Generic.ExprLike a => Agda.Syntax.Concrete.Generic.ExprLike (Agda.Utils.List1.List1 a)
instance Agda.Syntax.Concrete.Generic.ExprLike a => Agda.Syntax.Concrete.Generic.ExprLike (Agda.Utils.List2.List2 a)
instance Agda.Syntax.Concrete.Generic.ExprLike a => Agda.Syntax.Concrete.Generic.ExprLike (GHC.Maybe.Maybe a)
instance Agda.Syntax.Concrete.Generic.ExprLike a => Agda.Syntax.Concrete.Generic.ExprLike (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Concrete.Generic.ExprLike a => Agda.Syntax.Concrete.Generic.ExprLike (Agda.Syntax.Common.Named name a)
instance Agda.Syntax.Concrete.Generic.ExprLike a => Agda.Syntax.Concrete.Generic.ExprLike (Agda.Syntax.Common.Ranged a)
instance Agda.Syntax.Concrete.Generic.ExprLike a => Agda.Syntax.Concrete.Generic.ExprLike (Agda.Syntax.Common.WithHiding a)
instance Agda.Syntax.Concrete.Generic.ExprLike a => Agda.Syntax.Concrete.Generic.ExprLike (Agda.Syntax.Common.MaybePlaceholder a)
instance Agda.Syntax.Concrete.Generic.ExprLike a => Agda.Syntax.Concrete.Generic.ExprLike (Agda.Syntax.Concrete.RHS' a)
instance Agda.Syntax.Concrete.Generic.ExprLike a => Agda.Syntax.Concrete.Generic.ExprLike (Agda.Syntax.Concrete.TacticAttribute' a)
instance Agda.Syntax.Concrete.Generic.ExprLike a => Agda.Syntax.Concrete.Generic.ExprLike (Agda.Syntax.Concrete.TypedBinding' a)
instance Agda.Syntax.Concrete.Generic.ExprLike a => Agda.Syntax.Concrete.Generic.ExprLike (Agda.Syntax.Concrete.WhereClause' a)
instance (Agda.Syntax.Concrete.Generic.ExprLike a, Agda.Syntax.Concrete.Generic.ExprLike b) => Agda.Syntax.Concrete.Generic.ExprLike (Data.Either.Either a b)
instance (Agda.Syntax.Concrete.Generic.ExprLike a, Agda.Syntax.Concrete.Generic.ExprLike b) => Agda.Syntax.Concrete.Generic.ExprLike (a, b)
instance (Agda.Syntax.Concrete.Generic.ExprLike a, Agda.Syntax.Concrete.Generic.ExprLike b, Agda.Syntax.Concrete.Generic.ExprLike c) => Agda.Syntax.Concrete.Generic.ExprLike (a, b, c)
instance (Agda.Syntax.Concrete.Generic.ExprLike a, Agda.Syntax.Concrete.Generic.ExprLike b, Agda.Syntax.Concrete.Generic.ExprLike c, Agda.Syntax.Concrete.Generic.ExprLike d) => Agda.Syntax.Concrete.Generic.ExprLike (a, b, c, d)
instance Agda.Syntax.Concrete.Generic.ExprLike Agda.Syntax.Concrete.Expr
instance Agda.Syntax.Concrete.Generic.ExprLike Agda.Syntax.Concrete.FieldAssignment
instance Agda.Syntax.Concrete.Generic.ExprLike Agda.Syntax.Concrete.ModuleAssignment
instance Agda.Syntax.Concrete.Generic.ExprLike a => Agda.Syntax.Concrete.Generic.ExprLike (Agda.Syntax.Concrete.OpApp a)
instance Agda.Syntax.Concrete.Generic.ExprLike Agda.Syntax.Concrete.LamBinding
instance Agda.Syntax.Concrete.Generic.ExprLike Agda.Syntax.Concrete.LHS
instance (Agda.Syntax.Concrete.Generic.ExprLike qn, Agda.Syntax.Concrete.Generic.ExprLike e) => Agda.Syntax.Concrete.Generic.ExprLike (Agda.Syntax.Common.RewriteEqn' qn nm p e)
instance Agda.Syntax.Concrete.Generic.ExprLike Agda.Syntax.Concrete.LamClause
instance Agda.Syntax.Concrete.Generic.ExprLike Agda.Syntax.Concrete.DoStmt
instance Agda.Syntax.Concrete.Generic.ExprLike Agda.Syntax.Concrete.ModuleApplication
instance Agda.Syntax.Concrete.Generic.ExprLike Agda.Syntax.Concrete.Declaration


-- | Collecting fixity declarations (and polarity pragmas) for concrete
--   declarations.
module Agda.Syntax.Concrete.Fixity
type Fixities = Map Name Fixity'
type Polarities = Map Name [Occurrence]
class Monad m => MonadFixityError m
throwMultipleFixityDecls :: MonadFixityError m => [(Name, [Fixity'])] -> m a
throwMultiplePolarityPragmas :: MonadFixityError m => [Name] -> m a
warnUnknownNamesInFixityDecl :: (MonadFixityError m, HasCallStack) => [Name] -> m ()
warnUnknownNamesInPolarityPragmas :: (MonadFixityError m, HasCallStack) => [Name] -> m ()
warnUnknownFixityInMixfixDecl :: (MonadFixityError m, HasCallStack) => [Name] -> m ()
warnPolarityPragmasButNotPostulates :: (MonadFixityError m, HasCallStack) => [Name] -> m ()
data DoWarn
NoWarn :: DoWarn
DoWarn :: DoWarn

-- | Get the fixities and polarity pragmas from the current block. Doesn't
--   go inside modules and where blocks. The reason for this is that these
--   declarations have to appear at the same level (or possibly outside an
--   abstract or mutual block) as their target declaration.
fixitiesAndPolarities :: MonadFixityError m => DoWarn -> [Declaration] -> m (Fixities, Polarities)
instance GHC.Show.Show Agda.Syntax.Concrete.Fixity.DoWarn
instance GHC.Classes.Eq Agda.Syntax.Concrete.Fixity.DoWarn
instance GHC.Base.Semigroup Agda.Syntax.Concrete.Fixity.DeclaredNames
instance GHC.Base.Monoid Agda.Syntax.Concrete.Fixity.DeclaredNames
instance Agda.Syntax.Concrete.Fixity.MonadFixityError m => GHC.Base.Semigroup (Agda.Syntax.Concrete.Fixity.MonadicFixPol m)
instance Agda.Syntax.Concrete.Fixity.MonadFixityError m => GHC.Base.Monoid (Agda.Syntax.Concrete.Fixity.MonadicFixPol m)

module Agda.Syntax.Concrete.Definitions.Types

-- | The nice declarations. No fixity declarations and function definitions
--   are contained in a single constructor instead of spread out between
--   type signatures and clauses. The <tt>private</tt>, <tt>postulate</tt>,
--   <tt>abstract</tt> and <tt>instance</tt> modifiers have been
--   distributed to the individual declarations.
--   
--   Observe the order of components:
--   
--   Range Fixity' Access IsAbstract IsInstance TerminationCheck
--   PositivityCheck
--   
--   further attributes
--   
--   (Q)Name
--   
--   content (Expr, Declaration ...)
data NiceDeclaration

-- | <a>IsAbstract</a> argument: We record whether a declaration was made
--   in an <tt>abstract</tt> block.
--   
--   <a>ArgInfo</a> argument: Axioms and functions can be declared
--   irrelevant. (<a>Hiding</a> should be <a>NotHidden</a>.)
Axiom :: Range -> Access -> IsAbstract -> IsInstance -> ArgInfo -> Name -> Expr -> NiceDeclaration
NiceField :: Range -> Access -> IsAbstract -> IsInstance -> TacticAttribute -> Name -> Arg Expr -> NiceDeclaration
PrimitiveFunction :: Range -> Access -> IsAbstract -> Name -> Arg Expr -> NiceDeclaration
NiceMutual :: KwRange -> TerminationCheck -> CoverageCheck -> PositivityCheck -> [NiceDeclaration] -> NiceDeclaration
NiceModule :: Range -> Access -> IsAbstract -> Erased -> QName -> Telescope -> [Declaration] -> NiceDeclaration
NiceModuleMacro :: Range -> Access -> Erased -> Name -> ModuleApplication -> OpenShortHand -> ImportDirective -> NiceDeclaration
NiceOpen :: Range -> QName -> ImportDirective -> NiceDeclaration
NiceImport :: Range -> QName -> Maybe AsName -> OpenShortHand -> ImportDirective -> NiceDeclaration
NicePragma :: Range -> Pragma -> NiceDeclaration
NiceRecSig :: Range -> Erased -> Access -> IsAbstract -> PositivityCheck -> UniverseCheck -> Name -> [LamBinding] -> Expr -> NiceDeclaration
NiceDataSig :: Range -> Erased -> Access -> IsAbstract -> PositivityCheck -> UniverseCheck -> Name -> [LamBinding] -> Expr -> NiceDeclaration

-- | An uncategorized function clause, could be a function clause without
--   type signature or a pattern lhs (e.g. for irrefutable let). The
--   <a>Declaration</a> is the actual <a>FunClause</a>.
NiceFunClause :: Range -> Access -> IsAbstract -> TerminationCheck -> CoverageCheck -> Catchall -> Declaration -> NiceDeclaration
FunSig :: Range -> Access -> IsAbstract -> IsInstance -> IsMacro -> ArgInfo -> TerminationCheck -> CoverageCheck -> Name -> Expr -> NiceDeclaration

-- | Block of function clauses (we have seen the type signature before).
--   The <a>Declaration</a>s are the original declarations that were
--   processed into this <a>FunDef</a> and are only used in
--   <tt>notSoNiceDeclaration</tt>. Andreas, 2017-01-01: Because of issue
--   #2372, we add <a>IsInstance</a> here. An alias should know that it is
--   an instance.
FunDef :: Range -> [Declaration] -> IsAbstract -> IsInstance -> TerminationCheck -> CoverageCheck -> Name -> [Clause] -> NiceDeclaration
NiceDataDef :: Range -> Origin -> IsAbstract -> PositivityCheck -> UniverseCheck -> Name -> [LamBinding] -> [NiceConstructor] -> NiceDeclaration
NiceLoneConstructor :: KwRange -> [NiceConstructor] -> NiceDeclaration

-- | <tt>(Maybe Range)</tt> gives range of the 'pattern' declaration.
NiceRecDef :: Range -> Origin -> IsAbstract -> PositivityCheck -> UniverseCheck -> Name -> [RecordDirective] -> [LamBinding] -> [Declaration] -> NiceDeclaration
NicePatternSyn :: Range -> Access -> Name -> [WithHiding Name] -> Pattern -> NiceDeclaration
NiceGeneralize :: Range -> Access -> ArgInfo -> TacticAttribute -> Name -> Expr -> NiceDeclaration
NiceUnquoteDecl :: Range -> Access -> IsAbstract -> IsInstance -> TerminationCheck -> CoverageCheck -> [Name] -> Expr -> NiceDeclaration
NiceUnquoteDef :: Range -> Access -> IsAbstract -> TerminationCheck -> CoverageCheck -> [Name] -> Expr -> NiceDeclaration
NiceUnquoteData :: Range -> Access -> IsAbstract -> PositivityCheck -> UniverseCheck -> Name -> [Name] -> Expr -> NiceDeclaration
NiceOpaque :: KwRange -> [QName] -> [NiceDeclaration] -> NiceDeclaration
type TerminationCheck = TerminationCheck Measure

-- | Termination measure is, for now, a variable name.
type Measure = Name
type Catchall = Bool

-- | Only <a>Axiom</a>s.
type NiceConstructor = NiceTypeSignature

-- | Only <a>Axiom</a>s.
type NiceTypeSignature = NiceDeclaration

-- | One clause in a function definition. There is no guarantee that the
--   <a>LHS</a> actually declares the <a>Name</a>. We will have to check
--   that later.
data Clause
Clause :: Name -> Catchall -> LHS -> RHS -> WhereClause -> [Clause] -> Clause

-- | When processing a mutual block we collect the various checks present
--   in the block before combining them.
data MutualChecks
MutualChecks :: [TerminationCheck] -> [CoverageCheck] -> [PositivityCheck] -> MutualChecks
[mutualTermination] :: MutualChecks -> [TerminationCheck]
[mutualCoverage] :: MutualChecks -> [CoverageCheck]
[mutualPositivity] :: MutualChecks -> [PositivityCheck]

-- | In an inferred <tt>mutual</tt> block we keep accumulating nice
--   declarations until all of the lone signatures have an attached
--   definition. The type is therefore a bit span-like: we return an
--   initial segment (the inferred mutual block) together with leftovers.
data InferredMutual
InferredMutual :: MutualChecks -> [NiceDeclaration] -> [NiceDeclaration] -> InferredMutual
[inferredChecks] :: InferredMutual -> MutualChecks
[inferredBlock] :: InferredMutual -> [NiceDeclaration]
[inferredLeftovers] :: InferredMutual -> [NiceDeclaration]
extendInferredBlock :: NiceDeclaration -> InferredMutual -> InferredMutual

-- | In an `interleaved mutual' block we collect the data signatures,
--   function signatures, as well as their associated constructors and
--   function clauses respectively. Each signature is given a position in
--   the block (from 0 onwards) and each set of constructor / clauses is
--   given a *distinct* one. This allows for interleaved forward
--   declarations similar to what one gets in a new-style mutual block.
type InterleavedMutual = Map Name InterleavedDecl
data InterleavedDecl
InterleavedData :: DeclNum -> NiceDeclaration -> Maybe (DeclNum, List1 [NiceConstructor]) -> InterleavedDecl

-- | Internal number of the data signature.
[interleavedDeclNum] :: InterleavedDecl -> DeclNum

-- | The data signature.
[interleavedDeclSig] :: InterleavedDecl -> NiceDeclaration

-- | Constructors associated to the data signature.
[interleavedDataCons] :: InterleavedDecl -> Maybe (DeclNum, List1 [NiceConstructor])
InterleavedFun :: DeclNum -> NiceDeclaration -> Maybe (DeclNum, List1 ([Declaration], [Clause])) -> InterleavedDecl

-- | Internal number of the data signature.
[interleavedDeclNum] :: InterleavedDecl -> DeclNum

-- | The data signature.
[interleavedDeclSig] :: InterleavedDecl -> NiceDeclaration

-- | Function clauses associated to the function signature.
[interleavedFunClauses] :: InterleavedDecl -> Maybe (DeclNum, List1 ([Declaration], [Clause]))

-- | Numbering declarations in an <tt>interleaved mutual</tt> block.
type DeclNum = Int
isInterleavedFun :: InterleavedDecl -> Maybe ()
isInterleavedData :: InterleavedDecl -> Maybe ()
interleavedDecl :: Name -> InterleavedDecl -> [(DeclNum, NiceDeclaration)]

-- | Several declarations expect only type signatures as sub-declarations.
--   These are:
data KindOfBlock

-- | <pre>
--   postulate
--   </pre>
PostulateBlock :: KindOfBlock

-- | <tt>primitive</tt>. Ensured by parser.
PrimitiveBlock :: KindOfBlock

-- | <tt>instance</tt>. Actually, here all kinds of sub-declarations are
--   allowed a priori.
InstanceBlock :: KindOfBlock

-- | <tt>field</tt>. Ensured by parser.
FieldBlock :: KindOfBlock

-- | <tt>data ... where</tt>. Here we got a bad error message for Agda-2.5
--   (Issue 1698).
DataBlock :: KindOfBlock

-- | <tt>constructor</tt>, in <tt>interleaved mutual</tt>.
ConstructorBlock :: KindOfBlock
declName :: NiceDeclaration -> String
data InMutual

-- | we are nicifying a mutual block
InMutual :: InMutual

-- | we are nicifying decls not in a mutual block
NotInMutual :: InMutual

-- | The kind of the forward declaration.
data DataRecOrFun

-- | Name of a data type
DataName :: PositivityCheck -> UniverseCheck -> DataRecOrFun
[_kindPosCheck] :: DataRecOrFun -> PositivityCheck
[_kindUniCheck] :: DataRecOrFun -> UniverseCheck

-- | Name of a record type
RecName :: PositivityCheck -> UniverseCheck -> DataRecOrFun
[_kindPosCheck] :: DataRecOrFun -> PositivityCheck
[_kindUniCheck] :: DataRecOrFun -> UniverseCheck

-- | Name of a function.
FunName :: TerminationCheck -> CoverageCheck -> DataRecOrFun
isFunName :: DataRecOrFun -> Bool
sameKind :: DataRecOrFun -> DataRecOrFun -> Bool
terminationCheck :: DataRecOrFun -> TerminationCheck
coverageCheck :: DataRecOrFun -> CoverageCheck
positivityCheck :: DataRecOrFun -> PositivityCheck
mutualChecks :: DataRecOrFun -> MutualChecks
universeCheck :: DataRecOrFun -> UniverseCheck
instance GHC.Generics.Generic Agda.Syntax.Concrete.Definitions.Types.Clause
instance GHC.Show.Show Agda.Syntax.Concrete.Definitions.Types.Clause
instance GHC.Generics.Generic Agda.Syntax.Concrete.Definitions.Types.NiceDeclaration
instance GHC.Show.Show Agda.Syntax.Concrete.Definitions.Types.NiceDeclaration
instance GHC.Show.Show Agda.Syntax.Concrete.Definitions.Types.KindOfBlock
instance GHC.Classes.Ord Agda.Syntax.Concrete.Definitions.Types.KindOfBlock
instance GHC.Classes.Eq Agda.Syntax.Concrete.Definitions.Types.KindOfBlock
instance GHC.Show.Show Agda.Syntax.Concrete.Definitions.Types.InMutual
instance GHC.Classes.Eq Agda.Syntax.Concrete.Definitions.Types.InMutual
instance GHC.Show.Show Agda.Syntax.Concrete.Definitions.Types.DataRecOrFun
instance GHC.Classes.Eq Agda.Syntax.Concrete.Definitions.Types.DataRecOrFun
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.Definitions.Types.DataRecOrFun
instance GHC.Base.Semigroup Agda.Syntax.Concrete.Definitions.Types.MutualChecks
instance GHC.Base.Monoid Agda.Syntax.Concrete.Definitions.Types.MutualChecks
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.Definitions.Types.NiceDeclaration
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.Definitions.Types.NiceDeclaration
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.Definitions.Types.NiceDeclaration
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.Definitions.Types.Clause

module Agda.Syntax.Concrete.Definitions.Errors

-- | Exception with internal source code callstack
data DeclarationException
DeclarationException :: CallStack -> DeclarationException' -> DeclarationException
[deLocation] :: DeclarationException -> CallStack
[deException] :: DeclarationException -> DeclarationException'

-- | The exception type.
data DeclarationException'
MultipleEllipses :: Pattern -> DeclarationException'
InvalidName :: Name -> DeclarationException'
DuplicateDefinition :: Name -> DeclarationException'
DuplicateAnonDeclaration :: Range -> DeclarationException'
MissingWithClauses :: Name -> LHS -> DeclarationException'
WrongDefinition :: Name -> DataRecOrFun -> DataRecOrFun -> DeclarationException'
DeclarationPanic :: String -> DeclarationException'
WrongContentBlock :: KindOfBlock -> Range -> DeclarationException'

-- | In a mutual block, a clause could belong to any of the ≥2 type
--   signatures (<a>Name</a>).
AmbiguousFunClauses :: LHS -> List1 Name -> DeclarationException'

-- | In an interleaved mutual block, a constructor could belong to any of
--   the data signatures (<a>Name</a>)
AmbiguousConstructor :: Range -> Name -> [Name] -> DeclarationException'

-- | In a mutual block, all or none need a MEASURE pragma. <a>Range'</a> is
--   the one of the offending pragma or the mutual block.
InvalidMeasureMutual :: Range -> DeclarationException'
UnquoteDefRequiresSignature :: List1 Name -> DeclarationException'
BadMacroDef :: NiceDeclaration -> DeclarationException'

-- | An unfolding declaration was not the first declaration contained in an
--   opaque block.
UnfoldingOutsideOpaque :: KwRange -> DeclarationException'

-- | <tt>opaque</tt> block nested in a <tt>mutual</tt> block. This can
--   never happen, even with reordering. The <a>KwRange</a> is the one of
--   the <tt>opaque</tt> keyword.
OpaqueInMutual :: KwRange -> DeclarationException'

-- | A declaration that breaks an implicit mutual block (named by the
--   String argument) was present while the given lone type signatures were
--   still without their definitions.
DisallowedInterleavedMutual :: KwRange -> String -> List1 Name -> DeclarationException'
data DeclarationWarning
DeclarationWarning :: CallStack -> DeclarationWarning' -> DeclarationWarning
[dwLocation] :: DeclarationWarning -> CallStack
[dwWarning] :: DeclarationWarning -> DeclarationWarning'

-- | Non-fatal errors encountered in the Nicifier.
data DeclarationWarning'

-- | Empty <tt>abstract</tt> block.
EmptyAbstract :: KwRange -> DeclarationWarning'

-- | Empty <tt>data _ where</tt> block.
EmptyConstructor :: KwRange -> DeclarationWarning'

-- | Empty <tt>field</tt> block.
EmptyField :: KwRange -> DeclarationWarning'

-- | Empty <tt>variable</tt> block.
EmptyGeneralize :: KwRange -> DeclarationWarning'

-- | Empty <tt>instance</tt> block
EmptyInstance :: KwRange -> DeclarationWarning'

-- | Empty <tt>macro</tt> block.
EmptyMacro :: KwRange -> DeclarationWarning'

-- | Empty <tt>mutual</tt> block.
EmptyMutual :: KwRange -> DeclarationWarning'

-- | Empty <tt>postulate</tt> block.
EmptyPostulate :: KwRange -> DeclarationWarning'

-- | Empty <tt>private</tt> block.
EmptyPrivate :: KwRange -> DeclarationWarning'

-- | Empty <tt>primitive</tt> block.
EmptyPrimitive :: KwRange -> DeclarationWarning'

-- | A <a>Hidden</a> identifier in a <tt>variable</tt> declaration. Hiding
--   has no effect there as generalized variables are always hidden (or
--   instance variables).
HiddenGeneralize :: Range -> DeclarationWarning'

-- | A {-# CATCHALL #-} pragma that does not precede a function clause.
InvalidCatchallPragma :: Range -> DeclarationWarning'

-- | Invalid definition in a constructor block
InvalidConstructor :: Range -> DeclarationWarning'

-- | Invalid constructor block (not inside an interleaved mutual block)
InvalidConstructorBlock :: Range -> DeclarationWarning'

-- | A {-# NON_COVERING #-} pragma that does not apply to any function.
InvalidCoverageCheckPragma :: Range -> DeclarationWarning'

-- | A {-# NO_POSITIVITY_CHECK #-} pragma that does not apply to any data
--   or record type.
InvalidNoPositivityCheckPragma :: Range -> DeclarationWarning'

-- | A {-# NO_UNIVERSE_CHECK #-} pragma that does not apply to a data or
--   record type.
InvalidNoUniverseCheckPragma :: Range -> DeclarationWarning'

-- | A {-# TERMINATING #-} and {-# NON_TERMINATING #-} pragma that does not
--   apply to any function.
InvalidTerminationCheckPragma :: Range -> DeclarationWarning'

-- | Definitions (e.g. constructors or functions) without a declaration.
MissingDeclarations :: [(Name, Range)] -> DeclarationWarning'

-- | Declarations (e.g. type signatures) without a definition.
MissingDefinitions :: [(Name, Range)] -> DeclarationWarning'
NotAllowedInMutual :: Range -> String -> DeclarationWarning'

-- | <tt>private</tt> has no effect on <tt>open public</tt>. (But the user
--   might think so.) <a>KwRange</a> is the range of the <tt>public</tt>
--   keyword.
OpenPublicPrivate :: KwRange -> DeclarationWarning'

-- | <tt>abstract</tt> has no effect on <tt>open public</tt>. (But the user
--   might think so.) <a>KwRange</a> is the range of the <tt>public</tt>
--   keyword.
OpenPublicAbstract :: KwRange -> DeclarationWarning'
PolarityPragmasButNotPostulates :: [Name] -> DeclarationWarning'

-- | Pragma <tt>{-# NO_TERMINATION_CHECK #-}</tt> has been replaced by
--   <tt>{-# TERMINATING #-}</tt> and <tt>{-# NON_TERMINATING #-}</tt>.
PragmaNoTerminationCheck :: Range -> DeclarationWarning'

-- | <tt>COMPILE</tt> pragmas are not allowed in safe mode.
PragmaCompiled :: Range -> DeclarationWarning'

-- | <tt>ETA</tt> pragma is unsafe.
SafeFlagEta :: Range -> DeclarationWarning'

-- | <tt>INJECTIVE</tt> pragma is unsafe.
SafeFlagInjective :: Range -> DeclarationWarning'

-- | <tt>NON_COVERING</tt> pragma is unsafe.
SafeFlagNoCoverageCheck :: Range -> DeclarationWarning'

-- | <tt>NO_POSITIVITY_CHECK</tt> pragma is unsafe.
SafeFlagNoPositivityCheck :: Range -> DeclarationWarning'

-- | <tt>NO_UNIVERSE_CHECK</tt> pragma is unsafe.
SafeFlagNoUniverseCheck :: Range -> DeclarationWarning'

-- | <tt>NON_TERMINATING</tt> pragma is unsafe.
SafeFlagNonTerminating :: Range -> DeclarationWarning'

-- | <tt>POLARITY</tt> pragma is unsafe.
SafeFlagPolarity :: Range -> DeclarationWarning'

-- | <tt>TERMINATING</tt> pragma is unsafe.
SafeFlagTerminating :: Range -> DeclarationWarning'
ShadowingInTelescope :: List1 (Name, List2 Range) -> DeclarationWarning'
UnknownFixityInMixfixDecl :: [Name] -> DeclarationWarning'
UnknownNamesInFixityDecl :: [Name] -> DeclarationWarning'
UnknownNamesInPolarityPragmas :: [Name] -> DeclarationWarning'

-- | <tt>abstract</tt> block with nothing that can (newly) be made
--   abstract.
UselessAbstract :: KwRange -> DeclarationWarning'

-- | <tt>instance</tt> block with nothing that can (newly) become an
--   instance.
UselessInstance :: KwRange -> DeclarationWarning'

-- | <tt>macro</tt> block with nothing that can (newly) be made macro.
UselessMacro :: KwRange -> DeclarationWarning'

-- | <tt>private</tt> block with nothing that can (newly) be made private.
UselessPrivate :: KwRange -> DeclarationWarning'
declarationWarningName :: DeclarationWarning -> WarningName
declarationWarningName' :: DeclarationWarning' -> WarningName

-- | Nicifier warnings turned into errors in <tt>--safe</tt> mode.
unsafeDeclarationWarning :: DeclarationWarning -> Bool
unsafeDeclarationWarning' :: DeclarationWarning' -> Bool

-- | Pragmas not allowed in <tt>--safe</tt> mode produce an
--   <a>unsafeDeclarationWarning</a>.
unsafePragma :: CMaybe DeclarationWarning' m => Pragma -> m
instance GHC.Show.Show Agda.Syntax.Concrete.Definitions.Errors.DeclarationException'
instance GHC.Generics.Generic Agda.Syntax.Concrete.Definitions.Errors.DeclarationWarning'
instance GHC.Show.Show Agda.Syntax.Concrete.Definitions.Errors.DeclarationWarning'
instance GHC.Generics.Generic Agda.Syntax.Concrete.Definitions.Errors.DeclarationWarning
instance GHC.Show.Show Agda.Syntax.Concrete.Definitions.Errors.DeclarationWarning
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.Definitions.Errors.DeclarationWarning
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.Definitions.Errors.DeclarationWarning
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.Definitions.Errors.DeclarationWarning
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.Definitions.Errors.DeclarationWarning'
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.Definitions.Errors.DeclarationWarning'
instance Control.DeepSeq.NFData Agda.Syntax.Concrete.Definitions.Errors.DeclarationWarning'
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.Definitions.Errors.DeclarationException
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.Definitions.Errors.DeclarationException'
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.Definitions.Errors.DeclarationException'

module Agda.Syntax.Concrete.Definitions.Monad

-- | Nicifier monad. Preserve the state when throwing an exception.
newtype Nice a
Nice :: ReaderT NiceEnv (ExceptT DeclarationException (State NiceState)) a -> Nice a
[unNice] :: Nice a -> ReaderT NiceEnv (ExceptT DeclarationException (State NiceState)) a

-- | Run a Nicifier computation, return result and warnings (in
--   chronological order).
runNice :: NiceEnv -> Nice a -> (Either DeclarationException a, NiceWarnings)

-- | Nicifier parameters.
data NiceEnv
NiceEnv :: Bool -> NiceEnv

-- | We are in a module declared <tt>--safe</tt> which is not a builtin
--   module.
[safeButNotBuiltin] :: NiceEnv -> Bool

-- | Nicifier state.
data NiceState
NiceState :: LoneSigs -> TerminationCheck -> PositivityCheck -> UniverseCheck -> Catchall -> CoverageCheck -> NiceWarnings -> NameId -> NiceState

-- | Lone type signatures that wait for their definition.
[_loneSigs] :: NiceState -> LoneSigs

-- | Termination checking pragma waiting for a definition.
[_termChk] :: NiceState -> TerminationCheck

-- | Positivity checking pragma waiting for a definition.
[_posChk] :: NiceState -> PositivityCheck

-- | Universe checking pragma waiting for a data/rec signature or
--   definition.
[_uniChk] :: NiceState -> UniverseCheck

-- | Catchall pragma waiting for a function clause.
[_catchall] :: NiceState -> Catchall

-- | Coverage pragma waiting for a definition.
[_covChk] :: NiceState -> CoverageCheck

-- | Stack of warnings. Head is last warning.
[niceWarn] :: NiceState -> NiceWarnings

-- | We distinguish different <a>NoName</a>s (anonymous definitions) by a
--   unique <a>NameId</a>.
[_nameId] :: NiceState -> NameId
data LoneSig
LoneSig :: Range -> Name -> DataRecOrFun -> LoneSig
[loneSigRange] :: LoneSig -> Range

-- | If <a>isNoName</a>, this name can have a different <a>NameId</a> than
--   the key of <a>LoneSigs</a> pointing to it.
[loneSigName] :: LoneSig -> Name
[loneSigKind] :: LoneSig -> DataRecOrFun
type LoneSigs = -- | We retain the 'Name' also in the codomain since --   'Name' as a key is up to @Eq Name@ which ignores the range. --   However, without range names are not unique in case the --   user gives a second definition of the same name. --   This causes then problems in 'replaceSigs' which might --   replace the wrong signature. -- --   Another reason is that we want to distinguish different --   occurrences of 'NoName' in a mutual block (issue #4157). --   The 'NoName' in the codomain will have a unique 'NameId'. Map Name LoneSig
type NiceWarnings = -- | Stack of warnings. Head is last warning. [DeclarationWarning]

-- | Initial nicifier state.
initNiceState :: NiceState
lensNameId :: Lens' NiceState NameId
nextNameId :: Nice NameId

-- | Lens for field <a>_loneSigs</a>.
loneSigs :: Lens' NiceState LoneSigs

-- | Adding a lone signature to the state. Return the name (which is made
--   unique if <a>isNoName</a>).
addLoneSig :: Range -> Name -> DataRecOrFun -> Nice Name

-- | Remove a lone signature from the state.
removeLoneSig :: Name -> Nice ()

-- | Search for forward type signature.
getSig :: Name -> Nice (Maybe DataRecOrFun)

-- | Check that no lone signatures are left in the state.
noLoneSigs :: Nice Bool
forgetLoneSigs :: Nice ()

-- | Ensure that all forward declarations have been given a definition.
checkLoneSigs :: LoneSigs -> Nice ()

-- | Ensure that all forward declarations have been given a definition,
--   raising an error indicating *why* they would have had to have been
--   defined.
breakImplicitMutualBlock :: KwRange -> String -> Nice ()

-- | Get names of lone function signatures, plus their unique names.
loneFuns :: LoneSigs -> [(Name, Name)]

-- | Create a <a>LoneSigs</a> map from an association list.
loneSigsFromLoneNames :: [(Range, Name, DataRecOrFun)] -> LoneSigs

-- | Lens for field <a>_termChk</a>.
terminationCheckPragma :: Lens' NiceState TerminationCheck
withTerminationCheckPragma :: TerminationCheck -> Nice a -> Nice a
coverageCheckPragma :: Lens' NiceState CoverageCheck
withCoverageCheckPragma :: CoverageCheck -> Nice a -> Nice a

-- | Lens for field <a>_posChk</a>.
positivityCheckPragma :: Lens' NiceState PositivityCheck
withPositivityCheckPragma :: PositivityCheck -> Nice a -> Nice a

-- | Lens for field <a>_uniChk</a>.
universeCheckPragma :: Lens' NiceState UniverseCheck
withUniverseCheckPragma :: UniverseCheck -> Nice a -> Nice a

-- | Get universe check pragma from a data/rec signature. Defaults to
--   <a>YesUniverseCheck</a>.
getUniverseCheckFromSig :: Name -> Nice UniverseCheck

-- | Lens for field <a>_catchall</a>.
catchallPragma :: Lens' NiceState Catchall

-- | Get current catchall pragma, and reset it for the next clause.
popCatchallPragma :: Nice Catchall
withCatchallPragma :: Catchall -> Nice a -> Nice a

-- | Add a new warning.
niceWarning :: DeclarationWarning -> Nice ()
declarationException :: HasCallStack => DeclarationException' -> Nice a
declarationWarning' :: DeclarationWarning' -> CallStack -> Nice ()
declarationWarning :: HasCallStack => DeclarationWarning' -> Nice ()
instance GHC.Show.Show Agda.Syntax.Concrete.Definitions.Monad.LoneSig
instance Control.Monad.Error.Class.MonadError Agda.Syntax.Concrete.Definitions.Errors.DeclarationException Agda.Syntax.Concrete.Definitions.Monad.Nice
instance Control.Monad.State.Class.MonadState Agda.Syntax.Concrete.Definitions.Monad.NiceState Agda.Syntax.Concrete.Definitions.Monad.Nice
instance Control.Monad.Reader.Class.MonadReader Agda.Syntax.Concrete.Definitions.Monad.NiceEnv Agda.Syntax.Concrete.Definitions.Monad.Nice
instance GHC.Base.Monad Agda.Syntax.Concrete.Definitions.Monad.Nice
instance GHC.Base.Applicative Agda.Syntax.Concrete.Definitions.Monad.Nice
instance GHC.Base.Functor Agda.Syntax.Concrete.Definitions.Monad.Nice
instance Agda.Utils.Null.Null a => Agda.Utils.Null.Null (Agda.Syntax.Concrete.Definitions.Monad.Nice a)


module Agda.Syntax.Concrete.Attribute

-- | An attribute is a modifier for <a>ArgInfo</a>.
data Attribute
RelevanceAttribute :: Relevance -> Attribute
QuantityAttribute :: Quantity -> Attribute
TacticAttribute :: Ranged Expr -> Attribute
CohesionAttribute :: Cohesion -> Attribute
LockAttribute :: Lock -> Attribute

-- | (Conjunctive constraint.)
type LensAttribute a = (LensRelevance a, LensQuantity a, LensCohesion a, LensLock a)

-- | Modifiers for <a>Relevance</a>.
relevanceAttributeTable :: [(String, Relevance)]

-- | Modifiers for <a>Quantity</a>.
quantityAttributeTable :: [(String, Quantity)]
cohesionAttributeTable :: [(String, Cohesion)]

-- | Information about attributes (attribute, range, printed
--   representation).
--   
--   This information is returned by the parser. Code that calls the parser
--   should, if appropriate, complain if support for the given attributes
--   has not been enabled. This can be taken care of by
--   <a>checkAttributes</a>, which should not be called until after pragma
--   options have been set.
type Attributes = [(Attribute, Range, String)]

-- | Modifiers for <a>Quantity</a>.
lockAttributeTable :: [(String, Lock)]

-- | Concrete syntax for all attributes.
attributesMap :: Map String Attribute

-- | Parsing a string into an attribute.
stringToAttribute :: String -> Maybe Attribute

-- | Parsing an expression into an attribute.
exprToAttribute :: Expr -> Maybe Attribute

-- | Setting an attribute (in e.g. an <a>Arg</a>). Overwrites previous
--   value.
setAttribute :: LensAttribute a => Attribute -> a -> a

-- | Setting some attributes in left-to-right order. Blindly overwrites
--   previous settings.
setAttributes :: LensAttribute a => [Attribute] -> a -> a

-- | Setting <a>Relevance</a> if unset.
setPristineRelevance :: LensRelevance a => Relevance -> a -> Maybe a

-- | Setting <a>Quantity</a> if unset.
setPristineQuantity :: LensQuantity a => Quantity -> a -> Maybe a

-- | Setting <a>Cohesion</a> if unset.
setPristineCohesion :: LensCohesion a => Cohesion -> a -> Maybe a

-- | Setting <a>Lock</a> if unset.
setPristineLock :: LensLock a => Lock -> a -> Maybe a

-- | Setting an unset attribute (to e.g. an <a>Arg</a>).
setPristineAttribute :: LensAttribute a => Attribute -> a -> Maybe a

-- | Setting a list of unset attributes.
setPristineAttributes :: LensAttribute a => [Attribute] -> a -> Maybe a
isRelevanceAttribute :: Attribute -> Maybe Relevance
isQuantityAttribute :: Attribute -> Maybe Quantity
isTacticAttribute :: Attribute -> TacticAttribute
relevanceAttributes :: [Attribute] -> [Attribute]
quantityAttributes :: [Attribute] -> [Attribute]
tacticAttributes :: [Attribute] -> [Attribute]
instance GHC.Show.Show Agda.Syntax.Concrete.Attribute.Attribute
instance Agda.Syntax.Position.HasRange Agda.Syntax.Concrete.Attribute.Attribute
instance Agda.Syntax.Position.SetRange Agda.Syntax.Concrete.Attribute.Attribute
instance Agda.Syntax.Position.KillRange Agda.Syntax.Concrete.Attribute.Attribute

module Agda.Syntax.Parser.Monad

-- | The parse monad.
data Parser a

-- | The result of parsing something.
data ParseResult a
ParseOk :: ParseState -> a -> ParseResult a
ParseFailed :: ParseError -> ParseResult a

-- | The parser state. Contains everything the parser and the lexer could
--   ever need.
data ParseState
PState :: !SrcFile -> !PositionWithoutFile -> !PositionWithoutFile -> String -> !Char -> String -> LayoutContext -> LayoutStatus -> Keyword -> [LexState] -> ParseFlags -> ![ParseWarning] -> !Attributes -> ParseState
[parseSrcFile] :: ParseState -> !SrcFile

-- | position at current input location
[parsePos] :: ParseState -> !PositionWithoutFile

-- | position of last token
[parseLastPos] :: ParseState -> !PositionWithoutFile

-- | the current input
[parseInp] :: ParseState -> String

-- | the character before the input
[parsePrevChar] :: ParseState -> !Char

-- | the previous token
[parsePrevToken] :: ParseState -> String

-- | the stack of layout blocks
[parseLayout] :: ParseState -> LayoutContext

-- | the status of the coming layout block
[parseLayStatus] :: ParseState -> LayoutStatus

-- | the keyword for the coming layout block
[parseLayKw] :: ParseState -> Keyword

-- | the state of the lexer (states can be nested so we need a stack)
[parseLexState] :: ParseState -> [LexState]

-- | parametrization of the parser
[parseFlags] :: ParseState -> ParseFlags

-- | In reverse order.
[parseWarnings] :: ParseState -> ![ParseWarning]

-- | Every encountered attribute.
[parseAttributes] :: ParseState -> !Attributes

-- | Parse errors: what you get if parsing fails.
data ParseError

-- | Errors that arise at a specific position in the file
ParseError :: !SrcFile -> !PositionWithoutFile -> String -> String -> String -> ParseError

-- | The file in which the error occurred.
[errSrcFile] :: ParseError -> !SrcFile

-- | Where the error occurred.
[errPos] :: ParseError -> !PositionWithoutFile

-- | The remaining input.
[errInput] :: ParseError -> String

-- | The previous token.
[errPrevToken] :: ParseError -> String

-- | Hopefully an explanation of what happened.
[errMsg] :: ParseError -> String

-- | Parse errors that concern a range in a file.
OverlappingTokensError :: !Range' SrcFile -> ParseError

-- | The range of the bigger overlapping token
[errRange] :: ParseError -> !Range' SrcFile

-- | Parse errors that concern a whole file.
InvalidExtensionError :: !RangeFile -> [String] -> ParseError

-- | The file which the error concerns.
[errPath] :: ParseError -> !RangeFile
[errValidExts] :: ParseError -> [String]
ReadFileError :: !RangeFile -> IOError -> ParseError

-- | The file which the error concerns.
[errPath] :: ParseError -> !RangeFile
[errIOError] :: ParseError -> IOError

-- | Warnings for parsing.
data ParseWarning

-- | Parse errors that concern a range in a file.
OverlappingTokensWarning :: !Range' SrcFile -> ParseWarning

-- | The range of the bigger overlapping token
[warnRange] :: ParseWarning -> !Range' SrcFile

-- | Unsupported attribute.
UnsupportedAttribute :: Range -> !Maybe String -> ParseWarning

-- | Multiple attributes.
MultipleAttributes :: Range -> !Maybe String -> ParseWarning

-- | For context sensitive lexing alex provides what is called <i>start
--   codes</i> in the Alex documentation. It is really an integer
--   representing the state of the lexer, so we call it <tt>LexState</tt>
--   instead.
type LexState = Int

-- | We need to keep track of the context to do layout. The context
--   specifies the indentation columns of the open layout blocks. See
--   <a>Agda.Syntax.Parser.Layout</a> for more informaton.
data LayoutBlock

-- | Layout at specified <a>Column</a>, introduced by <a>Keyword</a>.
Layout :: Keyword -> LayoutStatus -> Column -> LayoutBlock

-- | The stack of layout blocks.
--   
--   When we encounter a layout keyword, we push a <a>Tentative</a> block
--   with <tt>noColumn</tt>. This is replaced by aproper column once we
--   reach the next token.
type LayoutContext = [LayoutBlock]

-- | Status of a layout column (see #1145). A layout column is
--   <a>Tentative</a> until we encounter a new line. This allows stacking
--   of layout keywords.
--   
--   Inside a <tt>LayoutContext</tt> the sequence of <a>Confirmed</a>
--   columns needs to be strictly increasing. 'Tentative columns between
--   <a>Confirmed</a> columns need to be strictly increasing as well.
data LayoutStatus

-- | The token defining the layout column was on the same line as the
--   layout keyword and we have not seen a new line yet.
Tentative :: LayoutStatus

-- | We have seen a new line since the layout keyword and the layout column
--   has not been superseded by a smaller column.
Confirmed :: LayoutStatus

-- | A (layout) column.
type Column = Int32

-- | Parser flags.
data ParseFlags
ParseFlags :: Bool -> ParseFlags

-- | Should comment tokens be returned by the lexer?
[parseKeepComments] :: ParseFlags -> Bool

-- | Constructs the initial state of the parser. The string argument is the
--   input string, the file path is only there because it's part of a
--   position.
initState :: Maybe RangeFile -> ParseFlags -> String -> [LexState] -> ParseState

-- | The default flags.
defaultParseFlags :: ParseFlags

-- | The most general way of parsing a string. The
--   <a>Agda.Syntax.Parser</a> will define more specialised functions that
--   supply the <a>ParseFlags</a> and the <a>LexState</a>.
parse :: ParseFlags -> [LexState] -> Parser a -> String -> ParseResult a

-- | The even more general way of parsing a string.
parsePosString :: Position -> ParseFlags -> [LexState] -> Parser a -> String -> ParseResult a

-- | Parses a string as if it were the contents of the given file Useful
--   for integrating preprocessors.
parseFromSrc :: ParseFlags -> [LexState] -> Parser a -> SrcFile -> String -> ParseResult a
setParsePos :: PositionWithoutFile -> Parser ()
setLastPos :: PositionWithoutFile -> Parser ()

-- | The parse interval is between the last position and the current
--   position.
getParseInterval :: Parser Interval
setPrevToken :: String -> Parser ()
getParseFlags :: Parser ParseFlags
getLexState :: Parser [LexState]
pushLexState :: LexState -> Parser ()
popLexState :: Parser ()

-- | Return the current layout block.
topBlock :: Parser (Maybe LayoutBlock)
popBlock :: Parser ()
pushBlock :: LayoutBlock -> Parser ()
getContext :: MonadState ParseState m => m LayoutContext
setContext :: LayoutContext -> Parser ()
modifyContext :: (LayoutContext -> LayoutContext) -> Parser ()

-- | When we see a layout keyword, by default we expect a <a>Tentative</a>
--   block.
resetLayoutStatus :: Parser ()

-- | Records a warning.
parseWarning :: ParseWarning -> Parser ()
parseWarningName :: ParseWarning -> WarningName

-- | Throw a parse error at the current position.
parseError :: String -> Parser a

-- | Fake a parse error at the specified position. Used, for instance, when
--   lexing nested comments, which when failing will always fail at the end
--   of the file. A more informative position is the beginning of the
--   failing comment.
parseErrorAt :: PositionWithoutFile -> String -> Parser a

-- | Use <a>parseErrorAt</a> or <a>parseError</a> as appropriate.
parseError' :: Maybe PositionWithoutFile -> String -> Parser a

-- | Report a parse error at the beginning of the given <a>Range'</a>.
parseErrorRange :: HasRange r => r -> String -> Parser a

-- | For lexical errors we want to report the current position as the site
--   of the error, whereas for parse errors the previous position is the
--   one we're interested in (since this will be the position of the token
--   we just lexed). This function does <a>parseErrorAt</a> the current
--   position.
lexError :: String -> Parser a
instance GHC.Show.Show Agda.Syntax.Parser.Monad.LayoutStatus
instance GHC.Classes.Eq Agda.Syntax.Parser.Monad.LayoutStatus
instance GHC.Show.Show Agda.Syntax.Parser.Monad.LayoutBlock
instance GHC.Show.Show Agda.Syntax.Parser.Monad.ParseFlags
instance GHC.Show.Show Agda.Syntax.Parser.Monad.ParseError
instance GHC.Show.Show Agda.Syntax.Parser.Monad.ParseWarning
instance GHC.Show.Show Agda.Syntax.Parser.Monad.ParseState
instance Control.Monad.Error.Class.MonadError Agda.Syntax.Parser.Monad.ParseError Agda.Syntax.Parser.Monad.Parser
instance Control.Monad.State.Class.MonadState Agda.Syntax.Parser.Monad.ParseState Agda.Syntax.Parser.Monad.Parser
instance GHC.Base.Monad Agda.Syntax.Parser.Monad.Parser
instance GHC.Base.Applicative Agda.Syntax.Parser.Monad.Parser
instance GHC.Base.Functor Agda.Syntax.Parser.Monad.Parser
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Parser.Monad.ParseResult a)
instance Control.DeepSeq.NFData Agda.Syntax.Parser.Monad.ParseWarning
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Parser.Monad.ParseWarning
instance Agda.Syntax.Position.HasRange Agda.Syntax.Parser.Monad.ParseWarning
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Parser.Monad.ParseError
instance Agda.Syntax.Position.HasRange Agda.Syntax.Parser.Monad.ParseError


-- | This module defines the things required by Alex and some other Alex
--   related things.
module Agda.Syntax.Parser.Alex

-- | This is what the lexer manipulates.
data AlexInput
AlexInput :: !SrcFile -> !PositionWithoutFile -> String -> !Char -> AlexInput

-- | File.
[lexSrcFile] :: AlexInput -> !SrcFile

-- | Current position.
[lexPos] :: AlexInput -> !PositionWithoutFile

-- | Current input.
[lexInput] :: AlexInput -> String

-- | Previously read character.
[lexPrevChar] :: AlexInput -> !Char

-- | A lens for <a>lexInput</a>.
lensLexInput :: Lens' AlexInput String

-- | Get the previously lexed character. Same as <a>lexPrevChar</a>. Alex
--   needs this to be defined to handle "patterns with a left-context".
alexInputPrevChar :: AlexInput -> Char

-- | Returns the next character, and updates the <a>AlexInput</a> value.
--   
--   This function is not suitable for use by Alex 2, because it can return
--   non-ASCII characters.
alexGetChar :: AlexInput -> Maybe (Char, AlexInput)

-- | Returns the next byte, and updates the <a>AlexInput</a> value.
--   
--   A trick is used to handle the fact that there are more than 256
--   Unicode code points. The function translates characters to bytes in
--   the following way:
--   
--   <ul>
--   <li>Whitespace characters other than '\t' and '\n' are translated to '
--   '.</li>
--   <li>Non-ASCII alphabetical characters are translated to 'z'.</li>
--   <li>Other non-ASCII printable characters are translated to '+'.</li>
--   <li>Everything else is translated to '\1'.</li>
--   </ul>
--   
--   Note that it is important that there are no keywords containing 'z',
--   '+', ' ' or '\1'.
--   
--   This function is used by Alex (version 3).
alexGetByte :: AlexInput -> Maybe (Word8, AlexInput)

-- | In the lexer, regular expressions are associated with lex actions
--   who's task it is to construct the tokens.
newtype LexAction r
LexAction :: (PreviousInput -> CurrentInput -> TokenLength -> Parser r) -> LexAction r
[runLexAction] :: LexAction r -> PreviousInput -> CurrentInput -> TokenLength -> Parser r

-- | Sometimes regular expressions aren't enough. Alex provides a way to do
--   arbitrary computations to see if the input matches. This is done with
--   a lex predicate.
type LexPredicate = ([LexState], ParseFlags) -> PreviousInput -> TokenLength -> CurrentInput -> Bool

-- | Conjunction of <a>LexPredicate</a>s.
(.&&.) :: LexPredicate -> LexPredicate -> LexPredicate

-- | Disjunction of <a>LexPredicate</a>s.
(.||.) :: LexPredicate -> LexPredicate -> LexPredicate

-- | Negation of <a>LexPredicate</a>s.
not' :: LexPredicate -> LexPredicate
type PreviousInput = AlexInput
type CurrentInput = AlexInput
type TokenLength = Int
getLexInput :: Parser AlexInput
setLexInput :: AlexInput -> Parser ()
instance GHC.Base.Functor Agda.Syntax.Parser.Alex.LexAction
instance GHC.Base.Applicative Agda.Syntax.Parser.Alex.LexAction
instance GHC.Base.Monad Agda.Syntax.Parser.Alex.LexAction
instance Control.Monad.State.Class.MonadState Agda.Syntax.Parser.Monad.ParseState Agda.Syntax.Parser.Alex.LexAction


-- | When lexing by hand (for instance string literals) we need to do some
--   looking ahead. The <a>LookAhead</a> monad keeps track of the position
--   we are currently looking at, and provides facilities to synchronise
--   the look-ahead position with the actual position of the <a>Parser</a>
--   monad (see <a>sync</a> and <a>rollback</a>).
module Agda.Syntax.Parser.LookAhead

-- | The LookAhead monad is basically a state monad keeping with an extra
--   <a>AlexInput</a>, wrapped around the <a>Parser</a> monad.
data LookAhead a

-- | Run a <a>LookAhead</a> computation. The first argument is the error
--   function.
runLookAhead :: (forall b. String -> LookAhead b) -> LookAhead a -> Parser a

-- | Throw an error message according to the supplied method.
lookAheadError :: String -> LookAhead a

-- | Get the current look-ahead position.
getInput :: LookAhead AlexInput

-- | Set the look-ahead position.
setInput :: AlexInput -> LookAhead ()

-- | Lift a computation in the <a>Parser</a> monad to the <a>LookAhead</a>
--   monad.
liftP :: Parser a -> LookAhead a

-- | Look at the next character. Fails if there are no more characters.
nextChar :: LookAhead Char

-- | Consume the next character. Does <a>nextChar</a> followed by
--   <a>sync</a>.
eatNextChar :: LookAhead Char

-- | Consume all the characters up to the current look-ahead position.
sync :: LookAhead ()

-- | Undo look-ahead. Restores the input from the <a>ParseState</a>.
rollback :: LookAhead ()

-- | Do a case on the current input string. If any of the given strings
--   match we move past it and execute the corresponding action. If no
--   string matches, we execute a default action, advancing the input one
--   character. This function only affects the look-ahead position.
match :: [(String, LookAhead a)] -> LookAhead a -> LookAhead a

-- | Same as <a>match</a> but takes the initial character from the first
--   argument instead of reading it from the input. Consequently, in the
--   default case the input is not advanced.
match' :: Char -> [(String, LookAhead a)] -> LookAhead a -> LookAhead a
instance GHC.Base.Monad Agda.Syntax.Parser.LookAhead.LookAhead
instance GHC.Base.Applicative Agda.Syntax.Parser.LookAhead.LookAhead
instance GHC.Base.Functor Agda.Syntax.Parser.LookAhead.LookAhead


-- | The code to lex string and character literals. Basically the same code
--   as in GHC.
module Agda.Syntax.Parser.StringLiterals

-- | Lex a string literal. Assumes that a double quote has been lexed.
litString :: LexAction Token

-- | Lex a character literal. Assumes that a single quote has been lexed. A
--   character literal is lexed in exactly the same way as a string
--   literal. Only before returning the token do we check that the lexed
--   string is of length 1. This is maybe not the most efficient way of
--   doing things, but on the other hand it will only be inefficient if
--   there is a lexical error.
litChar :: LexAction Token


-- | This module defines the lex action to lex nested comments. As is
--   well-known this cannot be done by regular expressions (which,
--   incidently, is probably the reason why C-comments don't nest).
--   
--   When scanning nested comments we simply keep track of the nesting
--   level, counting up for <i>open comments</i> and down for <i>close
--   comments</i>.
module Agda.Syntax.Parser.Comments

-- | Should comment tokens be output?
keepComments :: LexPredicate

-- | Should comment tokens be output?
keepCommentsM :: Parser Bool

-- | Manually lexing a block comment. Assumes an <i>open comment</i> has
--   been lexed. In the end the comment is discarded and <a>lexToken</a> is
--   called to lex a real token.
nestedComment :: LexAction Token

-- | Lex a hole (<tt>{! ... !}</tt>). Holes can be nested. Returns
--   <tt><a>TokSymbol</a> <a>SymQuestionMark</a></tt>.
hole :: LexAction Token

-- | Skip a block of text enclosed by the given open and close strings.
--   Assumes the first open string has been consumed. Open-close pairs may
--   be nested.
skipBlock :: String -> String -> LookAhead ()


-- | The lexer is generated by Alex (<a>http://www.haskell.org/alex</a>)
--   and is an adaptation of GHC's lexer. The main lexing function
--   <a>lexer</a> is called by the <a>Agda.Syntax.Parser.Parser</a> to get
--   the next token from the input.
module Agda.Syntax.Parser.Lexer

-- | Return the next token. This is the function used by Happy in the
--   parser.
--   
--   <pre>
--   lexer k = <a>lexToken</a> &gt;&gt;= k
--   </pre>
lexer :: (Token -> Parser a) -> Parser a

-- | This is the initial state for parsing a regular, non-literate file.
normal :: LexState
code :: Int

-- | The layout state. Entered when we see a layout keyword
--   (<a>withLayout</a>) and exited at the next token
--   (<a>newLayoutBlock</a>).
layout :: LexState

-- | We enter this state from <a>newLayoutBlock</a> when the token
--   following a layout keyword is to the left of (or at the same column
--   as) the current layout context. Example:
--   
--   <pre>
--   data Empty : Set where
--   foo : Empty -&gt; Nat
--   </pre>
--   
--   Here the second line is not part of the <tt>where</tt> clause since it
--   is has the same indentation as the <tt>data</tt> definition. What we
--   have to do is insert an empty layout block <tt>{}</tt> after the
--   <tt>where</tt>. The only thing that can happen in this state is that
--   <a>emptyLayout</a> is executed, generating the closing brace. The open
--   brace is generated when entering by <a>newLayoutBlock</a>.
empty_layout :: LexState

-- | This state is entered at the beginning of each line. You can't lex
--   anything in this state, and to exit you have to check the layout rule.
--   Done with <a>offsideRule</a>.
bol :: LexState

-- | This state can only be entered by the parser. In this state you can
--   only lex the keywords <tt>using</tt>, <tt>hiding</tt>,
--   <tt>renaming</tt> and <tt>to</tt>. Moreover they are only keywords in
--   this particular state. The lexer will never enter this state by
--   itself, that has to be done in the parser.
imp_dir :: LexState
data AlexReturn a
AlexEOF :: AlexReturn a
AlexError :: !AlexInput -> AlexReturn a
AlexSkip :: !AlexInput -> !Int -> AlexReturn a
AlexToken :: !AlexInput -> !Int -> a -> AlexReturn a

-- | This is the main lexing function generated by Alex.
alexScanUser :: ([LexState], ParseFlags) -> AlexInput -> Int -> AlexReturn (LexAction Token)


-- | This module contains the building blocks used to construct the lexer.
module Agda.Syntax.Parser.LexActions

-- | Scan the input to find the next token. Calls <a>alexScanUser</a>. This
--   is the main lexing function where all the work happens. The function
--   <a>lexer</a>, used by the parser is the continuation version of this
--   function.
lexToken :: Parser Token

-- | The most general way of parsing a token.
token :: (String -> Parser tok) -> LexAction tok

-- | Parse a token from an <a>Interval'</a> and the lexed string.
withInterval :: ((Interval, String) -> tok) -> LexAction tok

-- | Like <a>withInterval</a>, but applies a function to the string.
withInterval' :: (String -> a) -> ((Interval, a) -> tok) -> LexAction tok

-- | Return a token without looking at the lexed string.
withInterval_ :: (Interval -> r) -> LexAction r

-- | Executed for layout keywords. Enters the <a>layout</a> state and
--   performs the given action.
withLayout :: Keyword -> LexAction r -> LexAction r

-- | Prepend some parser manipulation to an action.
andThen :: Parser () -> LexAction r -> LexAction r
infixr 1 `andThen`

-- | Throw away the current lexeme.
skip :: LexAction Token

-- | Enter a new state without consuming any input.
begin :: LexState -> LexAction Token

-- | Exit the current state without consuming any input.
end :: LexAction Token

-- | Enter a new state and perform the given action.
beginWith :: LexState -> LexAction a -> LexAction a

-- | Exit the current state and perform the given action.
endWith :: LexAction a -> LexAction a

-- | Enter a new state throwing away the current lexeme.
begin_ :: LexState -> LexAction Token

-- | Exit the current state throwing away the current lexeme.
end_ :: LexAction Token

-- | For lexical errors we want to report the current position as the site
--   of the error, whereas for parse errors the previous position is the
--   one we're interested in (since this will be the position of the token
--   we just lexed). This function does <a>parseErrorAt</a> the current
--   position.
lexError :: String -> Parser a

-- | Parse a <a>Keyword</a> token, triggers layout for
--   <a>layoutKeywords</a>.
keyword :: Keyword -> LexAction Token

-- | Parse a <a>Symbol</a> token.
symbol :: Symbol -> LexAction Token

-- | Parse an identifier. Identifiers can be qualified (see <tt>Name</tt>).
--   Example: <tt>Foo.Bar.f</tt>
identifier :: LexAction Token
literal :: Read a => (a -> Literal) -> LexAction Token

-- | Parse a literal.
literal' :: (String -> a) -> (a -> Literal) -> LexAction Token
integer :: String -> Integer

-- | True when the given character is the next character of the input
--   string.
followedBy :: Char -> LexPredicate

-- | True if we are at the end of the file.
eof :: LexPredicate

-- | True if the given state appears somewhere on the state stack
inState :: LexState -> LexPredicate


-- | This module contains the lex actions that handle the layout rules. The
--   way it works is that the <a>Parser</a> monad keeps track of a stack of
--   <a>LayoutContext</a>s specifying the indentation of the layout blocks
--   in scope. For instance, consider the following incomplete (Haskell)
--   program:
--   
--   <pre>
--   f x = x'
--     where
--       x' = do y &lt;- foo x; bar ...
--   </pre>
--   
--   At the <tt>...</tt> the layout context would be
--   
--   <pre>
--   [Layout 12, Layout 4, Layout 0]
--   </pre>
--   
--   The closest layout block is the one following <tt>do</tt> which is
--   started by token <tt>y</tt> at column 12. The second closest block is
--   the <tt>where</tt> clause started by the <tt>x'</tt> token which has
--   indentation 4. Finally, there is a top-level layout block with
--   indentation 0.
--   
--   In April 2021 we changed layout handling in the lexer to allow
--   stacking of layout keywords on the same line, e.g.:
--   
--   <pre>
--   private module M where
--      postulate A : Set
--                private
--                  B : Set
--   </pre>
--   
--   The layout columns in the layout context (stack of layout blocks) can
--   have <a>LayoutStatus</a> either <a>Tentative</a> or <a>Confirmed</a>.
--   New layout columns following a layout keyword are tentative until we
--   see a new line. E.g.
--   
--   <ul>
--   <li>The first <tt>private</tt> block (column 8) is <a>Tentative</a>
--   when we encounter the layout keyword <tt>where</tt>.</li>
--   <li>The <tt>postulate</tt> block (column 12) is <a>Tentative</a> until
--   the newline after <tt>A : Set</tt>.</li>
--   </ul>
--   
--   In contrast,
--   
--   <ul>
--   <li>The <tt>module</tt> block (column 2) is <a>Confirmed</a> from the
--   beginning since the first token (<tt>postulate</tt>) after the layout
--   keyword <tt>where</tt> is on a new line.</li>
--   <li>The second <tt>private</tt> block (column 14) is also
--   <a>Confirmed</a> from the beginning (for the same reason).</li>
--   </ul>
--   
--   A new layout column has to be strictly above the last <b>confirmed</b>
--   column only. E.g., when encountering <tt>postulate</tt> at column 2
--   after <tt>where</tt>, the confirmed column is still 0, so this is a
--   valid start of the block following <tt>where</tt>.
--   
--   The column 8 of the <tt>private</tt> block never enters the
--   <a>Confirmed</a> status but remains <a>Tentative</a>. Also, this block
--   can never get more than the one declaration it has
--   (<tt>module...</tt>), because when the <tt>module</tt> block closes
--   due to a column &lt; 2, it closes as well. One could say that
--   tentative blocks buried under confirmed blocks are passive, the only
--   wait for their closing.
--   
--   To implement the process of block confirmation (function
--   <a>confirmLayout</a>), the lexer has to act on newline characters
--   (except for those in a block comment).
--   
--   <ul>
--   <li>In ordinary mode, when encountering a newline, we confirm the top
--   unconfirmed blocks. Example: The newline after <tt>A : Set</tt>
--   confirms the column 12 after <tt>postulate</tt>. Function:
--   <tt>confirmLayoutAtNewLine</tt>, state <tt>bol</tt>.</li>
--   <li>In the <tt>layout</tt> state following a layout keyword, a newline
--   does not confirm any block, but announces that the next block should
--   be confirmed from the start. Function:
--   <tt>confirmedLayoutComing</tt>.</li>
--   </ul>
--   
--   In order to implement <tt>confirmedLayoutComing</tt> we have a
--   <a>LayoutStatus</a> flag in the parse state (field
--   <tt>stateLayStatus</tt>). By default, for a new layout block, the
--   status is <a>Tentative</a> (unless we saw a newline).
--   
--   New layout blocks are created as follows. When a layout keyword is
--   encountered, we enter lexer state <a>layout</a> via function
--   <a>withLayout</a>. When we exit the <a>layout</a> state via
--   <a>newLayoutBlock</a> with a token that marks the new layout column,
--   we push a new <a>LayoutBlock</a> onto the <a>LayoutContext</a> using
--   the given column and the current <a>parseLayStatus</a> which is then
--   reset to <a>Tentative</a>.
--   
--   The new block is actually only pushed if the column is above the last
--   confirmed layout column (<tt>confirmedLayoutColumn</tt>). If this
--   check fails, we instead enter the <a>empty_layout</a> state. This
--   state produces the closing brace and is immediately left for
--   <a>bol</a> (beginning of line).
--   
--   (Remark: In <a>bol</a> we might confirm some tentative top blocks, but
--   this is irrelevant, since they will be closed immediately, given that
--   the current token is left of the confirmed column, and tentative
--   columns above it must be to the right of this column.)
--   
--   The <a>offsideRule</a> (state <a>bol</a>) is unchanged. It checks how
--   the first token on a new line relates to the top layout column, be it
--   tentative or confirmed. (Since we are on a new line, <a>Tentative</a>
--   can only happen when we popped some <a>Confirmed</a> columns and
--   continue popping the top <a>Tentative</a> columns here.) While the
--   token is to the left of the layout column, we keep closing blocks.
module Agda.Syntax.Parser.Layout

-- | Executed for layout keywords. Enters the <a>layout</a> state and
--   performs the given action.
withLayout :: Keyword -> LexAction r -> LexAction r

-- | Executed for the first token in each line (see <a>bol</a>), except
--   when the last token was a layout keyword.
--   
--   Checks the position of the token relative to the current layout
--   context. If the token is
--   
--   <ul>
--   <li><i>to the left</i> : Exit the current block and a return virtual
--   close brace (stay in the <a>bol</a> state).</li>
--   <li><i>same column</i> : Exit the <a>bol</a> state and return a
--   virtual semi colon.</li>
--   <li><i>to the right</i> : Exit the <a>bol</a> state and continue
--   lexing.</li>
--   </ul>
offsideRule :: LexAction Token

-- | Start a new layout block. This is how to get out of the <a>layout</a>
--   state. There are two possibilities:
--   
--   <ul>
--   <li>The current token is to the right of the confirmed layout
--   column.</li>
--   <li>The current token is to the left of or in the same column as the
--   confirmed layout column.</li>
--   </ul>
--   
--   In the first case everything is fine and we enter a new layout block
--   at the column of the current token. In the second case we have an
--   empty layout block so we enter the <a>empty_layout</a> state. In both
--   cases we return a virtual open brace without consuming any input.
--   
--   Entering a new state when we know we want to generate a virtual
--   <tt>{}</tt> may seem a bit roundabout. The thing is that we can only
--   generate one token at a time, so the way to generate two tokens is to
--   generate the first one and then enter a state in which the only thing
--   you can do is generate the second one.
newLayoutBlock :: LexAction Token

-- | This action is only executed from the <a>empty_layout</a> state. It
--   will exit this state, enter the <a>bol</a> state, and return a virtual
--   close brace (closing the empty layout block started by
--   <a>newLayoutBlock</a>).
emptyLayout :: LexAction Token

-- | At a new line, we confirm either existing tentative layout columns,
--   or, if the last token was a layout keyword, the expected new layout
--   column.
confirmLayout :: Parser ()


-- | Utility functions used in the Happy parser.
module Agda.Syntax.Parser.Helpers

-- | Grab leading OPTIONS pragmas.
takeOptionsPragmas :: [Declaration] -> Module

-- | Insert a top-level module if there is none. Also fix-up for the case
--   the declarations in the top-level module are not indented (this is
--   allowed as a special case).
figureOutTopLevelModule :: [Declaration] -> [Declaration]

-- | Create a name from a string.
mkName :: (Interval, String) -> Parser Name

-- | Create a qualified name from a list of strings
mkQName :: [(Interval, String)] -> Parser QName
mkDomainFree_ :: (NamedArg Binder -> NamedArg Binder) -> Maybe Pattern -> Name -> NamedArg Binder
mkRString :: (Interval, String) -> RString

-- | Create a qualified name from a string (used in pragmas). Range of each
--   name component is range of whole string. TODO: precise ranges!
pragmaQName :: (Interval, String) -> Parser QName
mkNamedArg :: Maybe QName -> Either QName Range -> Parser (NamedArg BoundName)

-- | Polarity parser.
polarity :: (Interval, String) -> Parser (Range, Occurrence)
recoverLayout :: [(Interval, String)] -> String
ensureUnqual :: QName -> Parser Name

-- | Result of parsing <tt>LamBinds</tt>.
data LamBinds' a
LamBinds :: a -> Maybe Hiding -> LamBinds' a

-- | A number of domain-free or typed bindings or record patterns.
[lamBindings] :: LamBinds' a -> a

-- | Followed by possibly a final absurd pattern.
[absurdBinding] :: LamBinds' a -> Maybe Hiding
type LamBinds = LamBinds' [LamBinding]
mkAbsurdBinding :: Hiding -> LamBinds
mkLamBinds :: a -> LamBinds' a

-- | Build a forall pi (forall x y z -&gt; ...)
forallPi :: List1 LamBinding -> Expr -> Expr

-- | Converts lambda bindings to typed bindings.
addType :: LamBinding -> TypedBinding

-- | Returns the value of the first erasure attribute, if any, or else the
--   default value of type <a>Erased</a>.
--   
--   Raises warnings for all attributes except for erasure attributes, and
--   for multiple erasure attributes.
onlyErased :: [Attr] -> Parser Erased

-- | Constructs extended lambdas.
extLam :: Range -> [Attr] -> List1 LamClause -> Parser Expr

-- | Constructs extended or absurd lambdas.
extOrAbsLam :: Range -> [Attr] -> Either ([LamBinding], Hiding) (List1 Expr) -> Parser Expr

-- | Interpret an expression as a list of names and (not parsed yet)
--   as-patterns
exprAsNamesAndPatterns :: Expr -> Maybe (List1 (Name, Maybe Expr))
exprAsNameAndPattern :: Expr -> Maybe (Name, Maybe Expr)
exprAsNameOrHiddenNames :: Expr -> Maybe (List1 (NamedArg (Name, Maybe Expr)))
boundNamesOrAbsurd :: List1 Expr -> Parser (Either (List1 (NamedArg Binder)) (List1 Expr))

-- | Match a pattern-matching "assignment" statement <tt>p &lt;- e</tt>
exprToAssignment :: Expr -> Parser (Maybe (Pattern, Range, Expr))

-- | Build a with-block
buildWithBlock :: [Either RewriteEqn (List1 (Named Name Expr))] -> Parser ([RewriteEqn], [Named Name Expr])

-- | Build a with-statement
buildWithStmt :: List1 (Named Name Expr) -> Parser [Either RewriteEqn (List1 (Named Name Expr))]
buildUsingStmt :: List1 Expr -> Parser RewriteEqn
buildSingleWithStmt :: Named Name Expr -> Parser (Either (Named Name (Pattern, Expr)) (Named Name Expr))

-- | Build a do-statement
defaultBuildDoStmt :: Expr -> [LamClause] -> Parser DoStmt
buildDoStmt :: Expr -> [LamClause] -> Parser DoStmt

-- | Turn an expression into a left hand side.
exprToLHS :: Expr -> Parser ([RewriteEqn] -> [WithExpr] -> LHS)

-- | Turn an expression into a pattern. Fails if the expression is not a
--   valid pattern.
exprToPattern :: Expr -> Parser Pattern

-- | Turn an expression into a name. Fails if the expression is not a valid
--   identifier.
exprToName :: Expr -> Parser Name

-- | When given expression is <tt>e1 = e2</tt>, turn it into a named
--   expression. Call this inside an implicit argument <tt>{e}</tt> or
--   <tt>{{e}}</tt>, where an equality must be a named argument (rather
--   than a cubical partial match).
maybeNamed :: Expr -> Parser (Named_ Expr)
patternSynArgs :: [NamedArg Binder] -> Parser [WithHiding Name]
mkLamClause :: Bool -> [Expr] -> RHS -> Parser LamClause
mkAbsurdLamClause :: Bool -> List1 Expr -> Parser LamClause
data RHSOrTypeSigs
JustRHS :: RHS -> RHSOrTypeSigs
TypeSigsRHS :: Expr -> RHSOrTypeSigs
patternToNames :: Pattern -> Parser (List1 (ArgInfo, Name))
funClauseOrTypeSigs :: [Attr] -> ([RewriteEqn] -> [WithExpr] -> LHS) -> [Either RewriteEqn (List1 (Named Name Expr))] -> RHSOrTypeSigs -> WhereClause -> Parser (List1 Declaration)
typeSig :: ArgInfo -> TacticAttribute -> Name -> Expr -> Declaration

-- | Parsed attribute.
data Attr
Attr :: Range -> String -> Attribute -> Attr

-- | Range includes the @.
[attrRange] :: Attr -> Range

-- | Concrete, user written attribute for error reporting.
[attrName] :: Attr -> String

-- | Parsed attribute.
[theAttr] :: Attr -> Attribute

-- | Parse an attribute.
toAttribute :: Range -> Expr -> Parser Attr

-- | Apply an attribute to thing (usually <a>Arg</a>). This will fail if
--   one of the attributes is already set in the thing to something else
--   than the default value.
applyAttr :: LensAttribute a => Attr -> a -> Parser a

-- | Apply attributes to thing (usually <a>Arg</a>). Expects a reversed
--   list of attributes. This will fail if one of the attributes is already
--   set in the thing to something else than the default value.
applyAttrs :: LensAttribute a => [Attr] -> a -> Parser a
applyAttrs1 :: LensAttribute a => List1 Attr -> a -> Parser a

-- | Set the tactic attribute of a binder
setTacticAttr :: List1 Attr -> NamedArg Binder -> NamedArg Binder

-- | Get the tactic attribute if present.
getTacticAttr :: [Attr] -> TacticAttribute

-- | Report a parse error if two attributes in the list are of the same
--   kind, thus, present conflicting information.
checkForUniqueAttribute :: (Attribute -> Bool) -> [Attr] -> Parser ()

-- | Report an attribute as conflicting (e.g., with an already set value).
errorConflictingAttribute :: Attr -> Parser a

-- | Report attributes as conflicting (e.g., with each other).
--   Precondition: List not emtpy.
errorConflictingAttributes :: [Attr] -> Parser a
instance GHC.Base.Functor Agda.Syntax.Parser.Helpers.LamBinds'
instance GHC.Show.Show Agda.Syntax.Parser.Helpers.RHSOrTypeSigs
instance Agda.Syntax.Position.HasRange Agda.Syntax.Parser.Helpers.Attr
instance Agda.Syntax.Position.SetRange Agda.Syntax.Parser.Helpers.Attr


-- | The parser is generated by Happy
--   (<a>http://www.haskell.org/happy</a>). - - Ideally, ranges should be
--   as precise as possible, to get messages that - emphasize precisely the
--   faulting term(s) upon error. - - However, interactive highlighting is
--   only applied at the end of each - mutual block, keywords are only
--   highlighted once (see - <a>Decl</a>). So if the ranges of two
--   declarations - interleave, one must ensure that keyword ranges are not
--   included in - the intersection. (Otherwise they are uncolored by the
--   interactive - highlighting.) -
module Agda.Syntax.Parser.Parser

-- | Parse a module.
moduleParser :: Parser Module
moduleNameParser :: Parser QName

-- | Parse an expression. Could be used in interactions.
exprParser :: Parser Expr

-- | Parse an expression followed by a where clause. Could be used in
--   interactions.
exprWhereParser :: Parser ExprWhere

-- | Parse the token stream. Used by the TeX compiler.
tokensParser :: Parser [Token]
holeContentParser :: Parser HoleContent

module Agda.Syntax.Parser

-- | Wrapped Parser type.
data Parser a

-- | Parse without top-level layout.
parse :: Parser a -> String -> PM (a, Attributes)
parsePosString :: Parser a -> Position -> String -> PM (a, Attributes)
parseFile :: Show a => Parser a -> RangeFile -> String -> PM ((a, Attributes), FileType)

-- | Parses a module.
moduleParser :: Parser Module

-- | Parses a module name.
moduleNameParser :: Parser QName

-- | Extensions supported by <a>parseFile</a>.
acceptableFileExts :: [String]

-- | Parses an expression.
exprParser :: Parser Expr

-- | Parses an expression followed by a where clause.
exprWhereParser :: Parser ExprWhere

-- | Parses an expression or some other content of an interaction hole.
holeContentParser :: Parser HoleContent

-- | Gives the parsed token stream (including comments).
tokensParser :: Parser [Token]

-- | Returns the contents of the given file.
readFilePM :: RangeFile -> PM Text

-- | Parse errors: what you get if parsing fails.
data ParseError

-- | Errors that arise at a specific position in the file
ParseError :: !SrcFile -> !PositionWithoutFile -> String -> String -> String -> ParseError

-- | The file in which the error occurred.
[errSrcFile] :: ParseError -> !SrcFile

-- | Where the error occurred.
[errPos] :: ParseError -> !PositionWithoutFile

-- | The remaining input.
[errInput] :: ParseError -> String

-- | The previous token.
[errPrevToken] :: ParseError -> String

-- | Hopefully an explanation of what happened.
[errMsg] :: ParseError -> String

-- | Parse errors that concern a range in a file.
OverlappingTokensError :: !Range' SrcFile -> ParseError

-- | The range of the bigger overlapping token
[errRange] :: ParseError -> !Range' SrcFile

-- | Parse errors that concern a whole file.
InvalidExtensionError :: !RangeFile -> [String] -> ParseError

-- | The file which the error concerns.
[errPath] :: ParseError -> !RangeFile
[errValidExts] :: ParseError -> [String]
ReadFileError :: !RangeFile -> IOError -> ParseError

-- | The file which the error concerns.
[errPath] :: ParseError -> !RangeFile
[errIOError] :: ParseError -> IOError

-- | Warnings for parsing.
data ParseWarning

-- | Parse errors that concern a range in a file.
OverlappingTokensWarning :: !Range' SrcFile -> ParseWarning

-- | The range of the bigger overlapping token
[warnRange] :: ParseWarning -> !Range' SrcFile

-- | Unsupported attribute.
UnsupportedAttribute :: Range -> !Maybe String -> ParseWarning

-- | Multiple attributes.
MultipleAttributes :: Range -> !Maybe String -> ParseWarning

-- | A monad for handling parse errors and warnings.
newtype PM a
PM :: ExceptT ParseError (StateT [ParseWarning] IO) a -> PM a
[unPM] :: PM a -> ExceptT ParseError (StateT [ParseWarning] IO) a

-- | Run a <a>PM</a> computation, returning a list of warnings in
--   first-to-last order and either a parse error or the parsed thing.
runPMIO :: MonadIO m => PM a -> m (Either ParseError a, [ParseWarning])
instance Control.Monad.State.Class.MonadState [Agda.Syntax.Parser.Monad.ParseWarning] Agda.Syntax.Parser.PM
instance Control.Monad.Error.Class.MonadError Agda.Syntax.Parser.Monad.ParseError Agda.Syntax.Parser.PM
instance Control.Monad.IO.Class.MonadIO Agda.Syntax.Parser.PM
instance GHC.Base.Monad Agda.Syntax.Parser.PM
instance GHC.Base.Applicative Agda.Syntax.Parser.PM
instance GHC.Base.Functor Agda.Syntax.Parser.PM

module Agda.Compiler.JS.Syntax
data Exp
Self :: Exp
Local :: LocalId -> Exp
Global :: GlobalId -> Exp
Undefined :: Exp
Null :: Exp
String :: Text -> Exp
Char :: Char -> Exp
Integer :: Integer -> Exp
Double :: Double -> Exp
Lambda :: Nat -> Exp -> Exp
Object :: Map MemberId Exp -> Exp
Array :: [(Comment, Exp)] -> Exp
Apply :: Exp -> [Exp] -> Exp
Lookup :: Exp -> MemberId -> Exp
If :: Exp -> Exp -> Exp -> Exp
BinOp :: Exp -> String -> Exp -> Exp
PreOp :: String -> Exp -> Exp
Const :: String -> Exp

-- | Arbitrary JS code.
PlainJS :: String -> Exp
newtype LocalId
LocalId :: Nat -> LocalId
newtype GlobalId
GlobalId :: [String] -> GlobalId
data MemberId
MemberId :: String -> MemberId
MemberIndex :: Int -> Comment -> MemberId
newtype Comment
Comment :: String -> Comment
data Export
Export :: JSQName -> Exp -> Export
[expName] :: Export -> JSQName
[defn] :: Export -> Exp
type JSQName = List1 MemberId
data Module
Module :: GlobalId -> [GlobalId] -> [Export] -> Maybe Exp -> Module
[modName] :: Module -> GlobalId
[imports] :: Module -> [GlobalId]
[exports] :: Module -> [Export]
[callMain] :: Module -> Maybe Exp
class Uses a
uses :: Uses a => a -> Set JSQName
uses :: (Uses a, a ~ t b, Foldable t, Uses b) => a -> Set JSQName
class Globals a
globals :: Globals a => a -> Set GlobalId
globals :: (Globals a, a ~ t b, Foldable t, Globals b) => a -> Set GlobalId
instance GHC.Show.Show Agda.Compiler.JS.Syntax.LocalId
instance GHC.Classes.Ord Agda.Compiler.JS.Syntax.LocalId
instance GHC.Classes.Eq Agda.Compiler.JS.Syntax.LocalId
instance GHC.Show.Show Agda.Compiler.JS.Syntax.GlobalId
instance GHC.Classes.Ord Agda.Compiler.JS.Syntax.GlobalId
instance GHC.Classes.Eq Agda.Compiler.JS.Syntax.GlobalId
instance GHC.Base.Monoid Agda.Compiler.JS.Syntax.Comment
instance GHC.Base.Semigroup Agda.Compiler.JS.Syntax.Comment
instance GHC.Show.Show Agda.Compiler.JS.Syntax.Comment
instance GHC.Show.Show Agda.Compiler.JS.Syntax.MemberId
instance GHC.Classes.Ord Agda.Compiler.JS.Syntax.MemberId
instance GHC.Classes.Eq Agda.Compiler.JS.Syntax.MemberId
instance GHC.Classes.Eq Agda.Compiler.JS.Syntax.Exp
instance GHC.Show.Show Agda.Compiler.JS.Syntax.Exp
instance GHC.Show.Show Agda.Compiler.JS.Syntax.Export
instance GHC.Show.Show Agda.Compiler.JS.Syntax.Module
instance Agda.Compiler.JS.Syntax.Globals a => Agda.Compiler.JS.Syntax.Globals [a]
instance Agda.Compiler.JS.Syntax.Globals a => Agda.Compiler.JS.Syntax.Globals (GHC.Maybe.Maybe a)
instance Agda.Compiler.JS.Syntax.Globals a => Agda.Compiler.JS.Syntax.Globals (Data.Map.Internal.Map k a)
instance (Agda.Compiler.JS.Syntax.Globals a, Agda.Compiler.JS.Syntax.Globals b) => Agda.Compiler.JS.Syntax.Globals (a, b)
instance (Agda.Compiler.JS.Syntax.Globals a, Agda.Compiler.JS.Syntax.Globals b, Agda.Compiler.JS.Syntax.Globals c) => Agda.Compiler.JS.Syntax.Globals (a, b, c)
instance Agda.Compiler.JS.Syntax.Globals Agda.Compiler.JS.Syntax.Comment
instance Agda.Compiler.JS.Syntax.Globals Agda.Compiler.JS.Syntax.Exp
instance Agda.Compiler.JS.Syntax.Globals Agda.Compiler.JS.Syntax.Export
instance Agda.Compiler.JS.Syntax.Globals Agda.Compiler.JS.Syntax.Module
instance Agda.Compiler.JS.Syntax.Uses a => Agda.Compiler.JS.Syntax.Uses [a]
instance Agda.Compiler.JS.Syntax.Uses a => Agda.Compiler.JS.Syntax.Uses (Data.Map.Internal.Map k a)
instance (Agda.Compiler.JS.Syntax.Uses a, Agda.Compiler.JS.Syntax.Uses b) => Agda.Compiler.JS.Syntax.Uses (a, b)
instance (Agda.Compiler.JS.Syntax.Uses a, Agda.Compiler.JS.Syntax.Uses b, Agda.Compiler.JS.Syntax.Uses c) => Agda.Compiler.JS.Syntax.Uses (a, b, c)
instance Agda.Compiler.JS.Syntax.Uses Agda.Compiler.JS.Syntax.Comment
instance Agda.Compiler.JS.Syntax.Uses Agda.Compiler.JS.Syntax.Exp
instance Agda.Compiler.JS.Syntax.Uses Agda.Compiler.JS.Syntax.Export
instance GHC.Classes.Eq Agda.Compiler.JS.Syntax.Comment
instance GHC.Classes.Ord Agda.Compiler.JS.Syntax.Comment

module Agda.Compiler.JS.Substitution
map :: Nat -> (Nat -> LocalId -> Exp) -> Exp -> Exp
shift :: Nat -> Exp -> Exp
shiftFrom :: Nat -> Nat -> Exp -> Exp
shifter :: Nat -> Nat -> LocalId -> Exp
subst :: Nat -> [Exp] -> Exp -> Exp
substituter :: Nat -> [Exp] -> Nat -> LocalId -> Exp
map' :: Nat -> (Nat -> LocalId -> Exp) -> Exp -> Exp
subst' :: Nat -> [Exp] -> Exp -> Exp
apply :: Exp -> [Exp] -> Exp
lookup :: Exp -> MemberId -> Exp
self :: Exp -> Exp -> Exp
fix :: Exp -> Exp
curriedApply :: Exp -> [Exp] -> Exp
curriedLambda :: Nat -> Exp -> Exp
emp :: Exp
union :: Exp -> Exp -> Exp
vine :: [MemberId] -> Exp -> Exp
object :: [([MemberId], Exp)] -> Exp

module Agda.Compiler.JS.Pretty
data JSModuleStyle
JSCJS :: JSModuleStyle
JSAMD :: JSModuleStyle
data Doc
Doc :: String -> Doc
Indent :: Int -> Doc -> Doc
Group :: Doc -> Doc
Beside :: Doc -> Doc -> Doc
Above :: Doc -> Doc -> Doc
Enclose :: Doc -> Doc -> Doc -> Doc
Space :: Doc
Empty :: Doc
minifiedCodeLinesLength :: Int
render :: Bool -> Doc -> String
($+$) :: Doc -> Doc -> Doc
infixr 5 $+$

-- | Separate by blank line.
($++$) :: Doc -> Doc -> Doc
infixr 5 $++$

-- | Separate by space that will be removed by minify.
--   
--   For non-removable space, use <tt>d &lt;&gt; " " &lt;&gt; d'</tt>.
(<+>) :: Doc -> Doc -> Doc
infixr 6 <+>
text :: String -> Doc
group :: Doc -> Doc
indentBy :: Int -> Doc -> Doc
enclose :: Doc -> Doc -> Doc -> Doc
space :: Doc
indent :: Doc -> Doc
hcat :: [Doc] -> Doc
vcat :: [Doc] -> Doc

-- | Concatenate vertically, separated by blank lines.
vsep :: [Doc] -> Doc
punctuate :: Doc -> [Doc] -> Doc
parens :: Doc -> Doc
brackets :: Doc -> Doc
braces :: Doc -> Doc

-- | Apply <a>parens</a> to <a>Doc</a> if boolean is true.
mparens :: Bool -> Doc -> Doc
unescape :: Char -> String
unescapes :: String -> Doc
class Pretty a
pretty :: Pretty a => (Nat, Bool, JSModuleStyle) -> a -> Doc
prettyShow :: Pretty a => Bool -> JSModuleStyle -> a -> String
class Pretties a
pretties :: Pretties a => (Nat, Bool, JSModuleStyle) -> a -> [Doc]
block :: (Nat, Bool, JSModuleStyle) -> Exp -> Doc
modname :: GlobalId -> Doc
exports :: (Nat, Bool, JSModuleStyle) -> Set JSQName -> [Export] -> Doc
variableName :: String -> String

-- | Check if a string is a valid JS identifier. The check ignores keywords
--   as we prepend z_ to our identifiers. The check is conservative and may
--   not admit all valid JS identifiers.
isValidJSIdent :: String -> Bool
instance GHC.Generics.Generic Agda.Compiler.JS.Pretty.JSModuleStyle
instance Agda.Compiler.JS.Pretty.Pretty a => Agda.Compiler.JS.Pretty.Pretties [a]
instance Agda.Compiler.JS.Pretty.Pretty a => Agda.Compiler.JS.Pretty.Pretties (Agda.Utils.List1.List1 a)
instance (Agda.Compiler.JS.Pretty.Pretty a, Agda.Compiler.JS.Pretty.Pretty b) => Agda.Compiler.JS.Pretty.Pretties (Data.Map.Internal.Map a b)
instance Agda.Compiler.JS.Pretty.Pretty Agda.Compiler.JS.Syntax.Exp
instance Agda.Compiler.JS.Pretty.Pretty [(Agda.Compiler.JS.Syntax.GlobalId, Agda.Compiler.JS.Syntax.Export)]
instance Agda.Compiler.JS.Pretty.Pretty a => Agda.Compiler.JS.Pretty.Pretty (GHC.Maybe.Maybe a)
instance (Agda.Compiler.JS.Pretty.Pretty a, Agda.Compiler.JS.Pretty.Pretty b) => Agda.Compiler.JS.Pretty.Pretty (a, b)
instance Agda.Compiler.JS.Pretty.Pretty Agda.Compiler.JS.Syntax.LocalId
instance Agda.Compiler.JS.Pretty.Pretty Agda.Compiler.JS.Syntax.GlobalId
instance Agda.Compiler.JS.Pretty.Pretty Agda.Compiler.JS.Syntax.MemberId
instance Agda.Compiler.JS.Pretty.Pretty Agda.Compiler.JS.Syntax.Comment
instance Agda.Compiler.JS.Pretty.Pretty Agda.Compiler.JS.Syntax.Module
instance Data.String.IsString Agda.Compiler.JS.Pretty.Doc
instance GHC.Base.Semigroup Agda.Compiler.JS.Pretty.Doc
instance GHC.Base.Monoid Agda.Compiler.JS.Pretty.Doc


-- | Basic data types for library management.
module Agda.Interaction.Library.Base

-- | A symbolic library name.
type LibName = String
data LibrariesFile
LibrariesFile :: FilePath -> Bool -> LibrariesFile

-- | E.g. <tt>~<i>.agda</i>libraries</tt>.
[lfPath] :: LibrariesFile -> FilePath

-- | The libraries file might not exist, but we may print its assumed
--   location in error messages.
[lfExists] :: LibrariesFile -> Bool

-- | A symbolic executable name.
type ExeName = Text
data ExecutablesFile
ExecutablesFile :: FilePath -> Bool -> ExecutablesFile

-- | E.g. <tt>~<i>.agda</i>executables</tt>.
[efPath] :: ExecutablesFile -> FilePath

-- | The executables file might not exist, but we may print its assumed
--   location in error messages.
[efExists] :: ExecutablesFile -> Bool

-- | The special name <tt>"."</tt> is used to indicated that the current
--   directory should count as a project root.
libNameForCurrentDir :: LibName

-- | A file can either belong to a project located at a given root
--   containing one or more .agda-lib files, or be part of the default
--   project.
data ProjectConfig
ProjectConfig :: FilePath -> [FilePath] -> !Int -> ProjectConfig
[configRoot] :: ProjectConfig -> FilePath
[configAgdaLibFiles] :: ProjectConfig -> [FilePath]

-- | How many directories above the Agda file is the <tt>.agda-lib</tt>
--   file located?
[configAbove] :: ProjectConfig -> !Int
DefaultProjectConfig :: ProjectConfig

-- | The options from an <tt>OPTIONS</tt> pragma (or a <tt>.agda-lib</tt>
--   file).
--   
--   In the future it might be nice to switch to a more structured
--   representation. Note that, currently, there is not a one-to-one
--   correspondence between list elements and options.
data OptionsPragma
OptionsPragma :: [String] -> Range -> OptionsPragma

-- | The options.
[pragmaStrings] :: OptionsPragma -> [String]

-- | The range of the options in the pragma (not including things like an
--   <tt>OPTIONS</tt> keyword).
[pragmaRange] :: OptionsPragma -> Range

-- | Content of a <tt>.agda-lib</tt> file.
data AgdaLibFile
AgdaLibFile :: LibName -> FilePath -> !Int -> [FilePath] -> [LibName] -> OptionsPragma -> AgdaLibFile

-- | The symbolic name of the library.
[_libName] :: AgdaLibFile -> LibName

-- | Path to this <tt>.agda-lib</tt> file (not content of the file).
[_libFile] :: AgdaLibFile -> FilePath

-- | How many directories above the Agda file is the <tt>.agda-lib</tt>
--   file located?
[_libAbove] :: AgdaLibFile -> !Int

-- | Roots where to look for the modules of the library.
[_libIncludes] :: AgdaLibFile -> [FilePath]

-- | Dependencies.
[_libDepends] :: AgdaLibFile -> [LibName]

-- | Default pragma options for all files in the library.
[_libPragmas] :: AgdaLibFile -> OptionsPragma
emptyLibFile :: AgdaLibFile

-- | Lenses for AgdaLibFile
libName :: Lens' AgdaLibFile LibName
libFile :: Lens' AgdaLibFile FilePath
libAbove :: Lens' AgdaLibFile Int
libIncludes :: Lens' AgdaLibFile [FilePath]
libDepends :: Lens' AgdaLibFile [LibName]
libPragmas :: Lens' AgdaLibFile OptionsPragma
type LineNumber = Int

-- | Information about which <tt>.agda-lib</tt> file we are reading and
--   from where in the <tt>libraries</tt> file it came from.
data LibPositionInfo
LibPositionInfo :: Maybe FilePath -> LineNumber -> FilePath -> LibPositionInfo

-- | Name of <tt>libraries</tt> file.
[libFilePos] :: LibPositionInfo -> Maybe FilePath

-- | Line number in <tt>libraries</tt> file.
[lineNumPos] :: LibPositionInfo -> LineNumber

-- | Library file.
[filePos] :: LibPositionInfo -> FilePath
data LibWarning
LibWarning :: Maybe LibPositionInfo -> LibWarning' -> LibWarning

-- | Library Warnings.
data LibWarning'
UnknownField :: String -> LibWarning'
libraryWarningName :: LibWarning -> WarningName
data LibError
LibError :: Maybe LibPositionInfo -> LibError' -> LibError

-- | Collected errors while processing library files.
data LibError'

-- | The user specified replacement for the default <tt>libraries</tt> file
--   does not exist.
LibrariesFileNotFound :: FilePath -> LibError'

-- | Raised when a library name could not successfully be resolved to an
--   <tt>.agda-lib</tt> file.
LibNotFound :: LibrariesFile -> LibName -> LibError'

-- | Raised when a library name is defined in several <tt>.agda-lib
--   files</tt>.
AmbiguousLib :: LibName -> [AgdaLibFile] -> LibError'

-- | The <tt>.agda-lib</tt> file could not be parsed.
LibParseError :: LibParseError -> LibError'

-- | An I/O Error occurred when reading a file.
ReadError :: IOException -> String -> LibError'

-- | The <tt>executables</tt> file contains duplicate entries.
DuplicateExecutable :: FilePath -> Text -> List2 (LineNumber, FilePath) -> LibError'

-- | Exceptions thrown by the <tt>.agda-lib</tt> parser.
data LibParseError

-- | An invalid library name, e.g., containing spaces.
BadLibraryName :: String -> LibParseError

-- | I/O error while reading file.
ReadFailure :: FilePath -> IOException -> LibParseError

-- | Missing these mandatory fields.
MissingFields :: List1 String -> LibParseError

-- | These fields occur each more than once.
DuplicateFields :: List1 String -> LibParseError

-- | At the given line number, a field name is missing before the
--   <tt>:</tt>.
MissingFieldName :: LineNumber -> LibParseError

-- | At the given line number, an invalid field name is encountered before
--   the <tt>:</tt>. (E.g., containing spaces.)
BadFieldName :: LineNumber -> String -> LibParseError

-- | At the given line number, the given field is not followed by
--   <tt>:</tt>.
MissingColonForField :: LineNumber -> String -> LibParseError

-- | At the given line number, indented text (content) is not preceded by a
--   field.
ContentWithoutField :: LineNumber -> LibParseError

-- | Collection of <a>LibError</a>s and <a>LibWarning</a>s.
type LibErrWarns = [Either LibError LibWarning]
warnings :: MonadWriter LibErrWarns m => List1 LibWarning -> m ()
warnings' :: MonadWriter LibErrWarns m => List1 LibWarning' -> m ()
raiseErrors' :: MonadWriter LibErrWarns m => List1 LibError' -> m ()
raiseErrors :: MonadWriter LibErrWarns m => List1 LibError -> m ()

-- | Collects <a>LibError</a>s and <a>LibWarning</a>s.
type LibErrorIO = WriterT LibErrWarns (StateT LibState IO)

-- | Throws <a>LibErrors</a> exceptions, still collects <a>LibWarning</a>s.
type LibM = ExceptT LibErrors (WriterT [LibWarning] (StateT LibState IO))

-- | Cache locations of project configurations and parsed
--   <tt>.agda-lib</tt> files.
type LibState = (Map FilePath ProjectConfig, Map FilePath AgdaLibFile)

-- | Collected errors when processing an <tt>.agda-lib</tt> file.
data LibErrors
LibErrors :: [AgdaLibFile] -> List1 LibError -> LibErrors
[libErrorsInstalledLibraries] :: LibErrors -> [AgdaLibFile]
[libErrors] :: LibErrors -> List1 LibError
getCachedProjectConfig :: (MonadState LibState m, MonadIO m) => FilePath -> m (Maybe ProjectConfig)
storeCachedProjectConfig :: (MonadState LibState m, MonadIO m) => FilePath -> ProjectConfig -> m ()
getCachedAgdaLibFile :: (MonadState LibState m, MonadIO m) => FilePath -> m (Maybe AgdaLibFile)
storeCachedAgdaLibFile :: (MonadState LibState m, MonadIO m) => FilePath -> AgdaLibFile -> m ()

-- | Pretty-print <a>LibError</a>.
formatLibError :: [AgdaLibFile] -> LibError -> Doc

-- | Pretty-print <a>LibErrors</a>.
formatLibErrors :: LibErrors -> Doc

-- | Does a parse error contain a line number?
hasLineNumber :: LibParseError -> Maybe LineNumber

-- | Compute a position position prefix.
--   
--   Depending on the error to be printed, it will
--   
--   <ul>
--   <li>either give the name of the <tt>libraries</tt> file and a line
--   inside it,</li>
--   <li>or give the name of the <tt>.agda-lib</tt> file.</li>
--   </ul>
formatLibPositionInfo :: LibPositionInfo -> LibParseError -> Doc
prettyInstalledLibraries :: [AgdaLibFile] -> Doc
instance GHC.Generics.Generic Agda.Interaction.Library.Base.LibrariesFile
instance GHC.Show.Show Agda.Interaction.Library.Base.LibrariesFile
instance GHC.Generics.Generic Agda.Interaction.Library.Base.ExecutablesFile
instance GHC.Show.Show Agda.Interaction.Library.Base.ExecutablesFile
instance GHC.Generics.Generic Agda.Interaction.Library.Base.ProjectConfig
instance GHC.Show.Show Agda.Interaction.Library.Base.OptionsPragma
instance GHC.Generics.Generic Agda.Interaction.Library.Base.AgdaLibFile
instance GHC.Show.Show Agda.Interaction.Library.Base.AgdaLibFile
instance GHC.Generics.Generic Agda.Interaction.Library.Base.LibPositionInfo
instance GHC.Show.Show Agda.Interaction.Library.Base.LibPositionInfo
instance GHC.Generics.Generic Agda.Interaction.Library.Base.LibWarning'
instance GHC.Show.Show Agda.Interaction.Library.Base.LibWarning'
instance GHC.Generics.Generic Agda.Interaction.Library.Base.LibWarning
instance GHC.Show.Show Agda.Interaction.Library.Base.LibWarning
instance GHC.Generics.Generic Agda.Interaction.Library.Base.LibParseError
instance GHC.Show.Show Agda.Interaction.Library.Base.LibParseError
instance GHC.Generics.Generic Agda.Interaction.Library.Base.LibError'
instance GHC.Show.Show Agda.Interaction.Library.Base.LibError'
instance GHC.Generics.Generic Agda.Interaction.Library.Base.LibError
instance GHC.Show.Show Agda.Interaction.Library.Base.LibError
instance GHC.Generics.Generic Agda.Interaction.Library.Base.LibErrors
instance GHC.Show.Show Agda.Interaction.Library.Base.LibErrors
instance Control.DeepSeq.NFData Agda.Interaction.Library.Base.LibErrors
instance Control.DeepSeq.NFData Agda.Interaction.Library.Base.LibError
instance Agda.Syntax.Common.Pretty.Pretty Agda.Interaction.Library.Base.LibError'
instance Control.DeepSeq.NFData Agda.Interaction.Library.Base.LibError'
instance Agda.Syntax.Common.Pretty.Pretty Agda.Interaction.Library.Base.LibParseError
instance Control.DeepSeq.NFData Agda.Interaction.Library.Base.LibParseError
instance Agda.Syntax.Common.Pretty.Pretty Agda.Interaction.Library.Base.LibWarning
instance Control.DeepSeq.NFData Agda.Interaction.Library.Base.LibWarning
instance Agda.Syntax.Common.Pretty.Pretty Agda.Interaction.Library.Base.LibWarning'
instance Control.DeepSeq.NFData Agda.Interaction.Library.Base.LibWarning'
instance Control.DeepSeq.NFData Agda.Interaction.Library.Base.LibPositionInfo
instance Control.DeepSeq.NFData Agda.Interaction.Library.Base.AgdaLibFile
instance GHC.Base.Semigroup Agda.Interaction.Library.Base.OptionsPragma
instance GHC.Base.Monoid Agda.Interaction.Library.Base.OptionsPragma
instance Control.DeepSeq.NFData Agda.Interaction.Library.Base.OptionsPragma
instance Control.DeepSeq.NFData Agda.Interaction.Library.Base.ProjectConfig
instance Control.DeepSeq.NFData Agda.Interaction.Library.Base.ExecutablesFile
instance Control.DeepSeq.NFData Agda.Interaction.Library.Base.LibrariesFile
instance Control.DeepSeq.NFData GHC.IO.Exception.IOException


-- | Parser for <tt>.agda-lib</tt> files.
--   
--   Example file:
--   
--   <pre>
--   name: Main
--   depend:
--     standard-library
--   include: .
--     src more-src
--   
--   
--   </pre>
--   
--   Should parse as:
--   
--   <pre>
--   AgdaLib
--     { libName     = <a>Main</a>
--     , libFile     = path_to_this_file
--     , libIncludes = [ "." , "src" , "more-src" ]
--     , libDepends  = [ "standard-library" ]
--     }
--   
--   </pre>
module Agda.Interaction.Library.Parse

-- | Parse <tt>.agda-lib</tt> file.
--   
--   Sets <a>libFile</a> name and turn mentioned include directories into
--   absolute pathes (provided the given <a>FilePath</a> is absolute).
parseLibFile :: FilePath -> IO (P AgdaLibFile)

-- | Break a comma-separated string. Result strings are <tt>trim</tt>med.
splitCommas :: String -> [String]

-- | Remove leading whitespace and line comment.
trimLineComment :: String -> String
runP :: P a -> (Either LibParseError a, [LibWarning'])
instance GHC.Show.Show Agda.Interaction.Library.Parse.GenericLine


-- | Ranges.
module Agda.Interaction.Highlighting.Range

-- | Character ranges. The first character in the file has position 1. Note
--   that the <a>to</a> position is considered to be outside of the range.
--   
--   Invariant: <tt><a>from</a> <a>&lt;=</a> <a>to</a></tt>.
data Range
Range :: !Int -> Range
[from, to] :: Range -> !Int

-- | The <a>Range</a> invariant.
rangeInvariant :: Range -> Bool

-- | Zero or more consecutive and separated ranges.
newtype Ranges
Ranges :: [Range] -> Ranges

-- | The <a>Ranges</a> invariant.
rangesInvariant :: Ranges -> Bool

-- | <a>True</a> iff the ranges overlap.
--   
--   The ranges are assumed to be well-formed.
overlapping :: Range -> Range -> Bool
overlappings :: Ranges -> Ranges -> Bool
empty :: Null a => a

-- | Converts a range to a list of positions.
rangeToPositions :: Range -> [Int]

-- | Converts several ranges to a list of positions.
rangesToPositions :: Ranges -> [Int]

-- | Converts a <a>Range'</a> to a <a>Ranges</a>.
rToR :: Range -> Ranges

-- | Converts a <a>Range'</a>, seen as a continuous range, to a
--   <a>Range</a>.
rangeToRange :: Range -> Range

-- | <tt>minus xs ys</tt> computes the difference between <tt>xs</tt> and
--   <tt>ys</tt>: the result contains those positions which are present in
--   <tt>xs</tt> but not in <tt>ys</tt>.
--   
--   Linear in the lengths of the input ranges.
minus :: Ranges -> Ranges -> Ranges
instance GHC.Show.Show Agda.Interaction.Highlighting.Range.Range
instance GHC.Classes.Ord Agda.Interaction.Highlighting.Range.Range
instance GHC.Classes.Eq Agda.Interaction.Highlighting.Range.Range
instance Control.DeepSeq.NFData Agda.Interaction.Highlighting.Range.Ranges
instance GHC.Show.Show Agda.Interaction.Highlighting.Range.Ranges
instance GHC.Classes.Eq Agda.Interaction.Highlighting.Range.Ranges
instance Agda.Utils.Null.Null Agda.Interaction.Highlighting.Range.Range
instance Control.DeepSeq.NFData Agda.Interaction.Highlighting.Range.Range


-- | Maps containing non-overlapping intervals.
module Agda.Utils.RangeMap

-- | A class that is intended to make it easy to swap between different
--   range map implementations.
--   
--   Note that some <a>RangeMap</a> operations are not included in this
--   class.
class IsBasicRangeMap a m | m -> a

-- | The map <tt><a>singleton</a> rs x</tt> contains the ranges from
--   <tt>rs</tt>, and every position in those ranges is associated with
--   <tt>x</tt>.
singleton :: IsBasicRangeMap a m => Ranges -> a -> m

-- | Converts range maps to <a>IntMap</a>s from positions to values.
toMap :: IsBasicRangeMap a m => m -> IntMap a

-- | Converts the map to a list. The ranges are non-overlapping and
--   non-empty, and earlier ranges precede later ones in the list.
toList :: IsBasicRangeMap a m => m -> [(Range, a)]

-- | Returns the smallest range covering everything in the map (or
--   <a>Nothing</a>, if the range would be empty).
--   
--   Note that the default implementation of this operation might be
--   inefficient.
coveringRange :: IsBasicRangeMap a m => m -> Maybe Range

-- | Like <a>singleton</a>, but with several <a>Ranges</a> instead of only
--   one.
several :: (IsBasicRangeMap a hl, Monoid hl) => [Ranges] -> a -> hl

-- | A strict pair type where the first argument must be an <a>Int</a>.
--   
--   This type is included because there is no <a>NFData</a> instance for
--   <a>Pair</a> in the package <tt>strict</tt> before version 4.
newtype PairInt a
PairInt :: Pair Int a -> PairInt a

-- | Maps containing non-overlapping intervals.
--   
--   The implementation does not use IntMap, because IntMap does not come
--   with a constant-time size function.
--   
--   Note the invariant which <a>RangeMap</a>s should satisfy
--   (<a>rangeMapInvariant</a>).
newtype RangeMap a
RangeMap :: Map Int (PairInt a) -> RangeMap a

-- | The keys are starting points of ranges, and the pairs contain
--   endpoints and values.
[rangeMap] :: RangeMap a -> Map Int (PairInt a)

-- | Invariant for <a>RangeMap</a>.
--   
--   The ranges must not be empty, and they must not overlap.
rangeMapInvariant :: RangeMap a -> Bool

-- | Converts a list of pairs of ranges and values to a <a>RangeMap</a>.
--   The ranges have to be non-overlapping and non-empty, and earlier
--   ranges have to precede later ones.
fromNonOverlappingNonEmptyAscendingList :: [(Range, a)] -> RangeMap a

-- | Inserts a value, along with a corresponding <a>Range</a>, into a
--   <a>RangeMap</a>. No attempt is made to merge adjacent ranges with
--   equal values.
--   
--   The function argument is used to combine values. The inserted value is
--   given as the first argument to the function.
insert :: (a -> a -> a) -> Range -> a -> RangeMap a -> RangeMap a

-- | The value of <tt><a>splitAt</a> p f</tt> is a pair <tt>(f1, f2)</tt>
--   which contains everything from <tt>f</tt>. All the positions in
--   <tt>f1</tt> are less than <tt>p</tt>, and all the positions in
--   <tt>f2</tt> are greater than or equal to <tt>p</tt>.
splitAt :: Int -> RangeMap a -> (RangeMap a, RangeMap a)

-- | Returns a <a>RangeMap</a> overlapping the given range, as well as the
--   rest of the map.
insideAndOutside :: Range -> RangeMap a -> (RangeMap a, RangeMap a)

-- | Restricts the <a>RangeMap</a> to the given range.
restrictTo :: Range -> RangeMap a -> RangeMap a
instance GHC.Show.Show a => GHC.Show.Show (Agda.Utils.RangeMap.PairInt a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Utils.RangeMap.RangeMap a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.Utils.RangeMap.RangeMap a)
instance Agda.Utils.Null.Null (Agda.Utils.RangeMap.RangeMap a)
instance Agda.Utils.RangeMap.IsBasicRangeMap a (Agda.Utils.RangeMap.RangeMap a)
instance GHC.Base.Semigroup a => GHC.Base.Semigroup (Agda.Utils.RangeMap.RangeMap a)
instance GHC.Base.Semigroup a => GHC.Base.Monoid (Agda.Utils.RangeMap.RangeMap a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Utils.RangeMap.PairInt a)


-- | Agda-specific benchmarking structure.
module Agda.Benchmarking

-- | Phases to allocate CPU time to.
data Phase

-- | Happy parsing and operator parsing.
Parsing :: Phase

-- | Import chasing.
Import :: Phase

-- | Reading interface files.
Deserialization :: Phase

-- | Scope checking and translation to abstract syntax.
Scoping :: Phase

-- | Type checking and translation to internal syntax.
Typing :: Phase

-- | Termination checking.
Termination :: Phase

-- | Positivity checking and polarity computation.
Positivity :: Phase

-- | Injectivity checking.
Injectivity :: Phase

-- | Checking for projection likeness.
ProjectionLikeness :: Phase

-- | Coverage checking and compilation to case trees.
Coverage :: Phase

-- | Generating highlighting info.
Highlighting :: Phase

-- | Writing interface files.
Serialization :: Phase

-- | Dead code elimination.
DeadCode :: Phase

-- | Unfolding all metas before serialization.
InterfaceInstantiateFull :: Phase

-- | Dead code reachable definitions subphase.
DeadCodeReachable :: Phase

-- | Subphase for <a>Termination</a>.
Graph :: Phase

-- | Subphase for <a>Termination</a>.
RecCheck :: Phase

-- | Subphase for <a>Termination</a>.
Reduce :: Phase

-- | Subphase for <a>Termination</a>.
Level :: Phase

-- | Subphase for <a>Termination</a>.
Compare :: Phase

-- | Subphase for <a>Termination</a>.
With :: Phase

-- | Subphase for <a>Import</a>.
ModuleName :: Phase

-- | Subphase for <a>Deserialization</a>: compacting interfaces.
Compaction :: Phase

-- | Subphase for <a>Serialization</a>.
BuildInterface :: Phase

-- | Subphase for <a>Serialization</a>.
Sort :: Phase

-- | Subphase for <a>Serialization</a>.
BinaryEncode :: Phase

-- | Subphase for <a>Serialization</a>.
Compress :: Phase

-- | Subphase for <a>Parsing</a>.
OperatorsExpr :: Phase

-- | Subphase for <a>Parsing</a>.
OperatorsPattern :: Phase

-- | Subphase for <a>Typing</a>: free variable computation.
Free :: Phase

-- | Subphase for <a>Typing</a>: occurs check for solving metas.
OccursCheck :: Phase

-- | Subphase for <a>Typing</a>: checking the LHS
CheckLHS :: Phase

-- | Subphase for <a>Typing</a>: checking the RHS
CheckRHS :: Phase

-- | Subphase for <a>Typing</a>: checking a type signature
TypeSig :: Phase

-- | Subphase for <a>Typing</a>: generalizing over <tt>variable</tt>s
Generalize :: Phase

-- | Subphase for <a>Typing</a>: solving instance goals
InstanceSearch :: Phase

-- | Subphase for <a>Typing</a>: evaluating elaborator reflection
Reflection :: Phase

-- | Subphase for <a>InstanceSearch</a>: collecting initial candidates
InitialCandidates :: Phase

-- | Subphase for <a>InstanceSearch</a>: checking candidates for validity
FilterCandidates :: Phase

-- | Subphase for <a>InstanceSearch</a>: ordering candidates for
--   specificity
OrderCandidates :: Phase

-- | Subphase for <a>InstanceSearch</a>: reducing overlapping instances
CheckOverlap :: Phase

-- | Subphase for <a>CheckLHS</a>: unification of the indices
UnifyIndices :: Phase

-- | Pretty printing names.
InverseScopeLookup :: Phase
TopModule :: TopLevelModuleName -> Phase
Typeclass :: QName -> Phase
Definition :: QName -> Phase
type Benchmark = Benchmark Phase
type Account = Account Phase
isModuleAccount :: Account -> Bool
isDefAccount :: Account -> Bool
isInternalAccount :: Account -> Bool

-- | Global variable to store benchmark statistics.
benchmarks :: IORef Benchmark

-- | Benchmark an IO computation and bill it to the given account.
billToIO :: Account -> IO a -> IO a

-- | Benchmark a pure computation and bill it to the given account.
billToPure :: Account -> a -> a
instance GHC.Generics.Generic Agda.Benchmarking.Phase
instance GHC.Show.Show Agda.Benchmarking.Phase
instance GHC.Classes.Ord Agda.Benchmarking.Phase
instance GHC.Classes.Eq Agda.Benchmarking.Phase
instance Agda.Syntax.Common.Pretty.Pretty Agda.Benchmarking.Phase
instance Control.DeepSeq.NFData Agda.Benchmarking.Phase
instance Agda.Utils.Benchmark.MonadBench GHC.Types.IO


-- | Computing the free variables of a term.
--   
--   The distinction between rigid and strongly rigid occurrences comes
--   from: Jason C. Reed, PhD thesis, 2009, page 96 (see also his LFMTP
--   2009 paper)
--   
--   The main idea is that x = t(x) is unsolvable if x occurs strongly
--   rigidly in t. It might have a solution if the occurrence is not
--   strongly rigid, e.g.
--   
--   x = f -&gt; suc (f (x ( y -&gt; k))) has x = f -&gt; suc (f (suc k))
--   
--   <ul>
--   <li><i>Jason C. Reed, PhD thesis, page 106</i></li>
--   </ul>
--   
--   Under coinductive constructors, occurrences are never strongly rigid.
--   Also, function types and lambdas do not establish strong rigidity.
--   Only inductive constructors do so. (See issue 1271).
--   
--   If you need the occurrence information for all free variables, you can
--   use <tt>freeVars</tt> which has amoungst others this instance <tt>
--   freeVars :: Term -&gt; VarMap </tt> From <tt>VarMap</tt>, specific
--   information can be extracted, e.g., <tt> relevantVars :: VarMap -&gt;
--   VarSet relevantVars = filterVarMap isRelevant </tt>
--   
--   To just check the status of a single free variable, there are more
--   efficient methods, e.g., <tt> freeIn :: Nat -&gt; Term -&gt; Bool
--   </tt>
--   
--   Tailored optimized variable checks can be implemented as semimodules
--   to <a>VarOcc'</a>, see, for example, <a>VarCounts</a> or
--   <a>SingleFlexRig</a>.
module Agda.TypeChecking.Free
newtype VarCounts
VarCounts :: IntMap Int -> VarCounts
[varCounts] :: VarCounts -> IntMap Int

-- | Gather free variables in a collection.
class Free t

-- | Any representation <tt>c</tt> of a set of variables need to be able to
--   be modified by a variable occurrence. This is to ensure that free
--   variable analysis is compositional. For instance, it should be
--   possible to compute `fv (v [u/x])` from `fv v` and `fv u`.
--   
--   In algebraic terminology, a variable set <tt>a</tt> needs to be
--   (almost) a left semimodule to the semiring <a>VarOcc'</a>.
class (Singleton MetaId a, Semigroup a, Monoid a, Semigroup c, Monoid c) => IsVarSet a c | c -> a

-- | Laws * Respects monoid operations: ``` withVarOcc o mempty == mempty
--   withVarOcc o (x &lt;&gt; y) == withVarOcc o x &lt;&gt; withVarOcc o y
--   ``` * Respects VarOcc composition: ``` withVarOcc oneVarOcc = id
--   withVarOcc (composeVarOcc o1 o2) = withVarOcc o1 . withVarOcc o2 ``` *
--   Respects VarOcc aggregation: ``` withVarOcc (o1 &lt;&gt; o2) x =
--   withVarOcc o1 x &lt;&gt; withVarOcc o2 x ``` Since the corresponding
--   unit law may fail, ``` withVarOcc mempty x = mempty ``` it is not
--   quite a semimodule.
withVarOcc :: IsVarSet a c => VarOcc' a -> c -> c

-- | Where should we skip sorts in free variable analysis?
data IgnoreSorts

-- | Do not skip.
IgnoreNot :: IgnoreSorts

-- | Skip when annotation to a type.
IgnoreInAnnotations :: IgnoreSorts

-- | Skip unconditionally.
IgnoreAll :: IgnoreSorts

-- | Collect all free variables together with information about their
--   occurrence.
--   
--   Doesn't go inside solved metas, but collects the variables from a
--   metavariable application <tt>X ts</tt> as <tt>flexibleVars</tt>.
freeVars :: (IsVarSet a c, Singleton Variable c, Free t) => t -> c
freeVars' :: (Free t, IsVarSet a c) => t -> FreeM a c
filterVarMap :: (VarOcc -> Bool) -> VarMap -> VarSet
filterVarMapToList :: (VarOcc -> Bool) -> VarMap -> [Variable]

-- | Compute free variables.
runFree :: (IsVarSet a c, Free t) => SingleVar c -> IgnoreSorts -> t -> c

-- | Rigid variables: either strongly rigid, unguarded, or weakly rigid.
rigidVars :: VarMap -> VarSet

-- | Variables under only and at least one inductive constructor(s).
stronglyRigidVars :: VarMap -> VarSet

-- | Variables at top or only under inductive record constructors λs and
--   Πs. The purpose of recording these separately is that they can still
--   become strongly rigid if put under a constructor whereas weakly rigid
--   ones stay weakly rigid.
unguardedVars :: VarMap -> VarSet
allVars :: VarMap -> VarSet

-- | Variables occuring in arguments of metas. These are only potentially
--   free, depending how the meta variable is instantiated. The set
--   contains the id's of the meta variables that this variable is an
--   argument to.
flexibleVars :: VarMap -> IntMap MetaSet

-- | Collect all free variables.
allFreeVars :: Free t => t -> VarSet

-- | Collect all relevant free variables, excluding the "unused" ones.
allRelevantVars :: Free t => t -> VarSet

-- | Collect all relevant free variables, possibly ignoring sorts.
allRelevantVarsIgnoring :: Free t => IgnoreSorts -> t -> VarSet
freeVarsIgnore :: (IsVarSet a c, Singleton Variable c, Free t) => IgnoreSorts -> t -> c
freeIn :: Free a => Nat -> a -> Bool
freeInIgnoringSorts :: Free a => Nat -> a -> Bool

-- | Is the variable bound by the abstraction actually used?
isBinderUsed :: Free a => Abs a -> Bool
relevantIn :: Free t => Nat -> t -> Bool
relevantInIgnoringSortAnn :: Free t => Nat -> t -> Bool

-- | Depending on the surrounding context of a variable, it's occurrence
--   can be classified as flexible or rigid, with finer distinctions.
--   
--   The constructors are listed in increasing order (wrt. information
--   content).
data FlexRig' a

-- | In arguments of metas. The set of metas is used by
--   '<a>NonLinMatch'</a> to generate the right blocking information. The
--   semantics is that the status of a variable occurrence may change if
--   one of the metas in the set gets solved. We may say the occurrence is
--   tainted by the meta variables in the set.
Flexible :: a -> FlexRig' a

-- | In arguments to variables and definitions.
WeaklyRigid :: FlexRig' a

-- | In top position, or only under inductive record constructors (unit).
Unguarded :: FlexRig' a

-- | Under at least one and only inductive constructors.
StronglyRigid :: FlexRig' a
type FlexRig = FlexRig' MetaSet
class LensFlexRig o a | o -> a
lensFlexRig :: LensFlexRig o a => Lens' o (FlexRig' a)
isFlexible :: LensFlexRig o a => o -> Bool
isUnguarded :: LensFlexRig o a => o -> Bool
isStronglyRigid :: LensFlexRig o a => o -> Bool
isWeaklyRigid :: LensFlexRig o a => o -> Bool

-- | Occurrence of free variables is classified by several dimensions.
--   Currently, we have <a>FlexRig</a> and <a>Modality</a>.
data VarOcc' a
VarOcc :: FlexRig' a -> Modality -> VarOcc' a
[varFlexRig] :: VarOcc' a -> FlexRig' a
[varModality] :: VarOcc' a -> Modality
type VarOcc = VarOcc' MetaSet

-- | Get the full occurrence information of a free variable.
varOccurrenceIn :: Free a => Nat -> a -> Maybe VarOcc

-- | Get the full occurrence information of a free variable.
flexRigOccurrenceIn :: Free a => Nat -> a -> Maybe FlexRig

-- | Is the term entirely closed (no free variables)?
closed :: Free t => t -> Bool

-- | A set of meta variables. Forms a monoid under union.
data MetaSet
insertMetaSet :: MetaId -> MetaSet -> MetaSet
foldrMetaSet :: (MetaId -> a -> a) -> a -> MetaSet -> a
metaSetToBlocker :: MetaSet -> Blocker
instance GHC.Base.Monoid c => GHC.Base.Monoid (Agda.TypeChecking.Free.RelevantIn c)
instance GHC.Base.Semigroup c => GHC.Base.Semigroup (Agda.TypeChecking.Free.RelevantIn c)
instance Agda.TypeChecking.Free.Lazy.IsVarSet a c => Agda.TypeChecking.Free.Lazy.IsVarSet a (Agda.TypeChecking.Free.RelevantIn c)
instance GHC.Base.Semigroup Agda.TypeChecking.Free.SingleFlexRig
instance GHC.Base.Monoid Agda.TypeChecking.Free.SingleFlexRig
instance Agda.TypeChecking.Free.Lazy.IsVarSet Agda.TypeChecking.Free.Lazy.MetaSet Agda.TypeChecking.Free.SingleFlexRig
instance GHC.Base.Semigroup Agda.TypeChecking.Free.SingleVarOcc
instance GHC.Base.Monoid Agda.TypeChecking.Free.SingleVarOcc
instance Agda.TypeChecking.Free.Lazy.IsVarSet Agda.TypeChecking.Free.Lazy.MetaSet Agda.TypeChecking.Free.SingleVarOcc
instance GHC.Base.Semigroup Agda.TypeChecking.Free.VarCounts
instance GHC.Base.Monoid Agda.TypeChecking.Free.VarCounts
instance Agda.TypeChecking.Free.Lazy.IsVarSet () Agda.TypeChecking.Free.VarCounts
instance Agda.Utils.Singleton.Singleton Agda.TypeChecking.Free.Lazy.Variable Agda.TypeChecking.Free.VarCounts
instance Agda.TypeChecking.Free.Lazy.IsVarSet () Agda.TypeChecking.Free.VarSet
instance Agda.TypeChecking.Free.Lazy.IsVarSet () [GHC.Types.Int]
instance Agda.TypeChecking.Free.Lazy.IsVarSet () Data.Semigroup.Internal.Any
instance Agda.TypeChecking.Free.Lazy.IsVarSet () Data.Semigroup.Internal.All

module Agda.TypeChecking.Substitute.Class

-- | Apply something to a bunch of arguments. Preserves blocking tags
--   (application can never resolve blocking).
class Apply t
apply :: Apply t => t -> Args -> t
applyE :: Apply t => t -> Elims -> t

-- | Apply to some default arguments.
applys :: Apply t => t -> [Term] -> t

-- | Apply to a single default argument.
apply1 :: Apply t => t -> Term -> t

-- | <tt>(abstract args v) <a>apply</a> args --&gt; v[args]</tt>.
class Abstract t
abstract :: Abstract t => Telescope -> t -> t

-- | Apply a substitution.
class DeBruijn (SubstArg a) => Subst a where {
    type SubstArg a;
}
applySubst :: Subst a => Substitution' (SubstArg a) -> a -> a
applySubst :: (Subst a, a ~ f b, Functor f, Subst b, SubstArg a ~ SubstArg b) => Substitution' (SubstArg a) -> a -> a

-- | Simple constraint alias for a <a>Subst</a> instance <tt>a</tt> with
--   arg type <tt>t</tt>.
type SubstWith t a = (Subst a, SubstArg a ~ t)

-- | <a>Subst</a> instance whose agument type is itself
type EndoSubst a = SubstWith a a

-- | <a>Subst</a> instance whose argument type is <a>Term</a>
type TermSubst a = SubstWith Term a

-- | Raise de Bruijn index, i.e. weakening
raise :: Subst a => Nat -> a -> a
raiseFrom :: Subst a => Nat -> Nat -> a -> a

-- | Replace de Bruijn index i by a <a>Term</a> in something.
subst :: Subst a => Int -> SubstArg a -> a -> a
strengthen :: Subst a => Impossible -> a -> a

-- | Replace what is now de Bruijn index 0, but go under n binders.
--   <tt>substUnder n u == subst n (raise n u)</tt>.
substUnder :: Subst a => Nat -> SubstArg a -> a -> a

-- | Checks whether the variable bound by the abstraction is actually used,
--   and, if <i>not</i>, returns the term within, <a>strengthen</a>ed to
--   live in the context <i>outside</i> the abstraction. See also
--   <a>isBinderUsed</a>.
isNoAbs :: (Free a, Subst a) => Abs a -> Maybe a

-- | Wrapper for types that do not contain variables (so applying a
--   substitution is the identity). Useful if you have a structure of types
--   that support substitution mixed with types that don't and need to
--   apply a substitution to the full structure.
newtype NoSubst t a
NoSubst :: a -> NoSubst t a
[unNoSubst] :: NoSubst t a -> a
idS :: Substitution' a
wkS :: Int -> Substitution' a -> Substitution' a
raiseS :: Int -> Substitution' a
consS :: DeBruijn a => a -> Substitution' a -> Substitution' a

-- | To replace index <tt>n</tt> by term <tt>u</tt>, do <tt>applySubst
--   (singletonS n u)</tt>. <tt> Γ, Δ ⊢ u : A
--   --------------------------------- Γ, Δ ⊢ singletonS |Δ| u : Γ, A, Δ
--   </tt>
singletonS :: DeBruijn a => Int -> a -> Substitution' a

-- | Single substitution without disturbing any deBruijn indices. <tt> Γ,
--   A, Δ ⊢ u : A --------------------------------- Γ, A, Δ ⊢ inplace |Δ| u
--   : Γ, A, Δ </tt>
inplaceS :: EndoSubst a => Int -> a -> Substitution' a

-- | Lift a substitution under k binders.
liftS :: Int -> Substitution' a -> Substitution' a

-- | <pre>
--      Γ ⊢ ρ : Δ, Ψ
--   -------------------
--   Γ ⊢ dropS |Ψ| ρ : Δ
--   
--   </pre>
dropS :: Int -> Substitution' a -> Substitution' a

-- | <pre>
--   applySubst (ρ <a>composeS</a> σ) v == applySubst ρ (applySubst σ v)
--   </pre>
composeS :: EndoSubst a => Substitution' a -> Substitution' a -> Substitution' a
splitS :: Int -> Substitution' a -> (Substitution' a, Substitution' a)
(++#) :: DeBruijn a => [a] -> Substitution' a -> Substitution' a
infixr 4 ++#

-- | <pre>
--   Γ ⊢ ρ : Δ  Γ ⊢ reverse vs : Θ
--   ----------------------------- (treating Nothing as having any type)
--     Γ ⊢ prependS vs ρ : Δ, Θ
--   
--   </pre>
prependS :: DeBruijn a => Impossible -> [Maybe a] -> Substitution' a -> Substitution' a

-- | <pre>
--     Γ ⊢ reverse vs : Δ
--   -----------------------------
--     Γ ⊢ parallelS vs ρ : Γ, Δ
--   
--   </pre>
--   
--   Note the <tt>Γ</tt> in <tt>Γ, Δ</tt>.
parallelS :: DeBruijn a => [a] -> Substitution' a

-- | Γ ⊢ (strengthenS ⊥ |Δ|) : Γ,Δ
strengthenS :: Impossible -> Int -> Substitution' a

-- | A "smart" variant of <a>Strengthen</a>. If <a>strengthenS</a> is
--   applied to a substitution with an outermost <a>Strengthen</a>
--   constructor, then the "error message" of that constructor is discarded
--   in favour of the <a>Impossible</a> argument of this function.
strengthenS' :: Impossible -> Int -> Substitution' a -> Substitution' a
lookupS :: EndoSubst a => Substitution' a -> Nat -> a

-- | lookupS (listS [(x0,t0)..(xn,tn)]) xi = ti, assuming x0 &lt; .. &lt;
--   xn.
listS :: EndoSubst a => [(Int, a)] -> Substitution' a

-- | <pre>
--   Γ, Ξ, Δ ⊢ raiseFromS |Δ| |Ξ| : Γ, Δ
--   </pre>
raiseFromS :: Nat -> Nat -> Substitution' a

-- | Instantiate an abstraction. Strict in the term.
absApp :: Subst a => Abs a -> SubstArg a -> a

-- | Instantiate an abstraction. Lazy in the term, which allow it to be
--   <b>IMPOSSIBLE</b> in the case where the variable shouldn't be used but
--   we cannot use <a>noabsApp</a>. Used in Apply.
lazyAbsApp :: Subst a => Abs a -> SubstArg a -> a

-- | Instantiate an abstraction that doesn't use its argument.
noabsApp :: Subst a => Impossible -> Abs a -> a
absBody :: Subst a => Abs a -> a
mkAbs :: (Subst a, Free a) => ArgName -> a -> Abs a
reAbs :: (Subst a, Free a) => Abs a -> Abs a
instance GHC.Base.Functor (Agda.TypeChecking.Substitute.Class.NoSubst t)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.TypeChecking.Substitute.Class.NoSubst t a)
instance GHC.Generics.Generic (Agda.TypeChecking.Substitute.Class.NoSubst t a)
instance Agda.TypeChecking.Substitute.DeBruijn.DeBruijn t => Agda.TypeChecking.Substitute.Class.Subst (Agda.TypeChecking.Substitute.Class.NoSubst t a)
instance Agda.TypeChecking.Substitute.Class.Subst Agda.Syntax.Abstract.Name.QName


-- | This module defines the notion of a scope and operations on scopes.
module Agda.Syntax.Scope.Base

-- | A scope is a named collection of names partitioned into public and
--   private names.
data Scope
Scope :: ModuleName -> [ModuleName] -> ScopeNameSpaces -> Map QName ModuleName -> Maybe DataOrRecordModule -> Scope
[scopeName] :: Scope -> ModuleName
[scopeParents] :: Scope -> [ModuleName]
[scopeNameSpaces] :: Scope -> ScopeNameSpaces
[scopeImports] :: Scope -> Map QName ModuleName
[scopeDatatypeModule] :: Scope -> Maybe DataOrRecordModule
data DataOrRecordModule
IsDataModule :: DataOrRecordModule
IsRecordModule :: DataOrRecordModule

-- | See <a>Access</a>.
data NameSpaceId

-- | Things not exported by this module.
PrivateNS :: NameSpaceId

-- | Things defined and exported by this module.
PublicNS :: NameSpaceId

-- | Things from open public, exported by this module.
ImportedNS :: NameSpaceId
allNameSpaces :: [NameSpaceId]
type ScopeNameSpaces = [(NameSpaceId, NameSpace)]
localNameSpace :: Access -> NameSpaceId
nameSpaceAccess :: NameSpaceId -> Access

-- | Get a <a>NameSpace</a> from <a>Scope</a>.
scopeNameSpace :: NameSpaceId -> Scope -> NameSpace

-- | A lens for <a>scopeNameSpaces</a>
updateScopeNameSpaces :: (ScopeNameSpaces -> ScopeNameSpaces) -> Scope -> Scope

-- | `<tt>Monadic'</tt> lens (Functor sufficient).
updateScopeNameSpacesM :: Functor m => (ScopeNameSpaces -> m ScopeNameSpaces) -> Scope -> m Scope

-- | The complete information about the scope at a particular program point
--   includes the scope stack, the local variables, and the context
--   precedence.
data ScopeInfo
ScopeInfo :: ModuleName -> Map ModuleName Scope -> LocalVars -> LocalVars -> !PrecedenceStack -> NameMap -> ModuleMap -> InScopeSet -> Fixities -> Polarities -> ScopeInfo
[_scopeCurrent] :: ScopeInfo -> ModuleName
[_scopeModules] :: ScopeInfo -> Map ModuleName Scope

-- | The variables that will be bound at the end of the current block of
--   variables (i.e. clause). We collect them here instead of binding them
--   immediately so we can avoid shadowing between variables in the same
--   variable block.
[_scopeVarsToBind] :: ScopeInfo -> LocalVars
[_scopeLocals] :: ScopeInfo -> LocalVars
[_scopePrecedence] :: ScopeInfo -> !PrecedenceStack
[_scopeInverseName] :: ScopeInfo -> NameMap
[_scopeInverseModule] :: ScopeInfo -> ModuleMap
[_scopeInScope] :: ScopeInfo -> InScopeSet

-- | Maps concrete names C.Name to fixities
[_scopeFixities] :: ScopeInfo -> Fixities

-- | Maps concrete names C.Name to polarities
[_scopePolarities] :: ScopeInfo -> Polarities

-- | For the sake of highlighting, the <a>_scopeInverseName</a> map also
--   stores the <a>KindOfName</a> of an <tt>A.QName</tt>.
data NameMapEntry
NameMapEntry :: KindOfName -> List1 QName -> NameMapEntry

-- | The <a>anameKind</a>.
[qnameKind] :: NameMapEntry -> KindOfName

-- | Possible renderings of the abstract name.
[qnameConcrete] :: NameMapEntry -> List1 QName
type NameMap = Map QName NameMapEntry
type ModuleMap = Map ModuleName [QName]

-- | Local variables.
type LocalVars = AssocList Name LocalVar

-- | For each bound variable, we want to know whether it was bound by a λ,
--   Π, module telescope, pattern, or <tt>let</tt>.
data BindingSource

-- | <tt>λ</tt> (currently also used for <tt>Π</tt> and module parameters)
LambdaBound :: BindingSource

-- | <tt>f ... =</tt>. Remember <a>Hiding</a> for pattern variables
--   <tt>{x}</tt> and <tt>{{x}}</tt>. This information is only used for
--   checking pattern synonyms. It is not serialized.
PatternBound :: Hiding -> BindingSource

-- | <pre>
--   let ... in
--   </pre>
LetBound :: BindingSource

-- | <pre>
--   | ... in q
--   </pre>
WithBound :: BindingSource

-- | A local variable can be shadowed by an import. In case of reference to
--   a shadowed variable, we want to report a scope error.
data LocalVar
LocalVar :: Name -> BindingSource -> [AbstractName] -> LocalVar

-- | Unique ID of local variable.
[localVar] :: LocalVar -> Name

-- | Kind of binder used to introduce the variable (<tt>λ</tt>,
--   <tt>let</tt>, ...).
[localBindingSource] :: LocalVar -> BindingSource

-- | If this list is not empty, the local variable is shadowed by one or
--   more imports.
[localShadowedBy] :: LocalVar -> [AbstractName]

-- | Shadow a local name by a non-empty list of imports.
shadowLocal :: List1 AbstractName -> LocalVar -> LocalVar

-- | Treat patternBound variable as a module parameter
patternToModuleBound :: LocalVar -> LocalVar

-- | Project name of unshadowed local variable.
notShadowedLocal :: LocalVar -> Maybe Name

-- | Get all locals that are not shadowed <b>by imports</b>.
notShadowedLocals :: LocalVars -> AssocList Name Name

-- | Lenses for ScopeInfo components
scopeCurrent :: Lens' ScopeInfo ModuleName
scopeModules :: Lens' ScopeInfo (Map ModuleName Scope)
scopeVarsToBind :: Lens' ScopeInfo LocalVars
scopeLocals :: Lens' ScopeInfo LocalVars
scopePrecedence :: Lens' ScopeInfo PrecedenceStack
scopeInverseName :: Lens' ScopeInfo NameMap
scopeInverseModule :: Lens' ScopeInfo ModuleMap
scopeInScope :: Lens' ScopeInfo InScopeSet
scopeFixities :: Lens' ScopeInfo Fixities
scopePolarities :: Lens' ScopeInfo Polarities
scopeFixitiesAndPolarities :: Lens' ScopeInfo (Fixities, Polarities)

-- | Lens for <a>scopeVarsToBind</a>.
updateVarsToBind :: (LocalVars -> LocalVars) -> ScopeInfo -> ScopeInfo
setVarsToBind :: LocalVars -> ScopeInfo -> ScopeInfo

-- | Lens for <a>scopeLocals</a>.
updateScopeLocals :: (LocalVars -> LocalVars) -> ScopeInfo -> ScopeInfo
setScopeLocals :: LocalVars -> ScopeInfo -> ScopeInfo

-- | A <tt>NameSpace</tt> contains the mappings from concrete names that
--   the user can write to the abstract fully qualified names that the type
--   checker wants to read.
data NameSpace
NameSpace :: NamesInScope -> ModulesInScope -> InScopeSet -> NameSpace

-- | Maps concrete names to a list of abstract names.
[nsNames] :: NameSpace -> NamesInScope

-- | Maps concrete module names to a list of abstract module names.
[nsModules] :: NameSpace -> ModulesInScope

-- | All abstract names targeted by a concrete name in scope. Computed by
--   <a>recomputeInScopeSets</a>.
[nsInScope] :: NameSpace -> InScopeSet
type ThingsInScope a = Map Name (List1 a)
type NamesInScope = ThingsInScope AbstractName
type ModulesInScope = ThingsInScope AbstractModule
type InScopeSet = Set QName

-- | Set of types consisting of exactly <a>AbstractName</a> and
--   <a>AbstractModule</a>.
--   
--   A GADT just for some dependent-types trickery.
data InScopeTag a
[NameTag] :: InScopeTag AbstractName
[ModuleTag] :: InScopeTag AbstractModule

-- | Type class for some dependent-types trickery.
class Ord a => InScope a
inScopeTag :: InScope a => InScopeTag a

-- | <tt>inNameSpace</tt> selects either the name map or the module name
--   map from a <a>NameSpace</a>. What is selected is determined by result
--   type (using the dependent-type trickery).
inNameSpace :: forall a. InScope a => NameSpace -> ThingsInScope a

-- | Non-dependent tag for name or module.
data NameOrModule
NameNotModule :: NameOrModule
ModuleNotName :: NameOrModule

-- | For the sake of parsing left-hand sides, we distinguish constructor
--   and record field names from defined names.
data KindOfName

-- | Constructor name (<a>Inductive</a> or don't know).
ConName :: KindOfName

-- | Constructor name (definitely <a>CoInductive</a>).
CoConName :: KindOfName

-- | Record field name.
FldName :: KindOfName

-- | Name of a pattern synonym.
PatternSynName :: KindOfName

-- | Name to be generalized
GeneralizeName :: KindOfName

-- | Generalizable variable from a let open
DisallowedGeneralizeName :: KindOfName

-- | Name of a macro
MacroName :: KindOfName

-- | A name that can only be quoted. Previous category <tt>DefName</tt>:
--   (Refined in a flat manner as Enum and Bounded are not hereditary.)
QuotableName :: KindOfName

-- | Name of a <tt>data</tt>.
DataName :: KindOfName

-- | Name of a <tt>record</tt>.
RecName :: KindOfName

-- | Name of a defined function.
FunName :: KindOfName

-- | Name of a <tt>postulate</tt>.
AxiomName :: KindOfName

-- | Name of a <tt>primitive</tt>.
PrimName :: KindOfName

-- | A <tt>DefName</tt>, but either other kind or don't know which kind.
--   End <tt>DefName</tt>. Keep these together in sequence, for sake of
--   <tt>isDefName</tt>!
OtherDefName :: KindOfName
isDefName :: KindOfName -> Bool
isConName :: KindOfName -> Maybe Induction
conKindOfName :: Induction -> KindOfName

-- | For ambiguous constructors, we might have both alternatives of
--   <a>Induction</a>. In this case, we default to <a>ConName</a>.
conKindOfName' :: Foldable t => t Induction -> KindOfName

-- | For ambiguous constructors, we might have both alternatives of
--   <a>Induction</a>. In this case, we default to <a>Inductive</a>.
approxConInduction :: Foldable t => t Induction -> Induction
exactConInduction :: Foldable t => t Induction -> Maybe Induction

-- | Only return <tt>[Co]ConName</tt> if no ambiguity.
exactConName :: Foldable t => t Induction -> Maybe KindOfName

-- | A set of <a>KindOfName</a>, for the sake of <a>elemKindsOfNames</a>.
data KindsOfNames
AllKindsOfNames :: KindsOfNames

-- | Only these kinds.
SomeKindsOfNames :: Set KindOfName -> KindsOfNames

-- | All but these Kinds.
ExceptKindsOfNames :: Set KindOfName -> KindsOfNames
elemKindsOfNames :: KindOfName -> KindsOfNames -> Bool
allKindsOfNames :: KindsOfNames
someKindsOfNames :: [KindOfName] -> KindsOfNames
exceptKindsOfNames :: [KindOfName] -> KindsOfNames

-- | Decorate something with <a>KindOfName</a>
data WithKind a
WithKind :: KindOfName -> a -> WithKind a
[theKind] :: WithKind a -> KindOfName
[kindedThing] :: WithKind a -> a

-- | Where does a name come from?
--   
--   This information is solely for reporting to the user, see
--   <a>whyInScope</a>.
data WhyInScope

-- | Defined in this module.
Defined :: WhyInScope

-- | Imported from another module.
Opened :: QName -> WhyInScope -> WhyInScope

-- | Imported by a module application.
Applied :: QName -> WhyInScope -> WhyInScope

-- | A decoration of <a>QName</a>.
data AbstractName
AbsName :: QName -> KindOfName -> WhyInScope -> NameMetadata -> AbstractName

-- | The resolved qualified name.
[anameName] :: AbstractName -> QName

-- | The kind (definition, constructor, record field etc.).
[anameKind] :: AbstractName -> KindOfName

-- | Explanation where this name came from.
[anameLineage] :: AbstractName -> WhyInScope

-- | Additional information needed during scope checking. Currently used
--   for generalized data/record params.
[anameMetadata] :: AbstractName -> NameMetadata
data NameMetadata
NoMetadata :: NameMetadata
GeneralizedVarsMetadata :: Map QName Name -> NameMetadata

-- | A decoration of abstract syntax module names.
data AbstractModule
AbsModule :: ModuleName -> WhyInScope -> AbstractModule

-- | The resolved module name.
[amodName] :: AbstractModule -> ModuleName

-- | Explanation where this name came from.
[amodLineage] :: AbstractModule -> WhyInScope

-- | Van Laarhoven lens on <a>anameName</a>.
lensAnameName :: Lens' AbstractName QName

-- | Van Laarhoven lens on <a>amodName</a>.
lensAmodName :: Lens' AbstractModule ModuleName
data ResolvedName

-- | Local variable bound by λ, Π, module telescope, pattern, <tt>let</tt>.
VarName :: Name -> BindingSource -> ResolvedName
[resolvedVar] :: ResolvedName -> Name

-- | What kind of binder?
[resolvedBindingSource] :: ResolvedName -> BindingSource

-- | Function, data/record type, postulate.
DefinedName :: Access -> AbstractName -> Suffix -> ResolvedName

-- | Record field name. Needs to be distinguished to parse copatterns.
FieldName :: List1 AbstractName -> ResolvedName

-- | Data or record constructor name.
ConstructorName :: Set Induction -> List1 AbstractName -> ResolvedName

-- | Name of pattern synonym.
PatternSynResName :: List1 AbstractName -> ResolvedName

-- | Unbound name.
UnknownName :: ResolvedName

-- | Why is a resolved name ambiguous? What did it resolve to?
--   
--   Invariant (statically enforced): At least two resolvents in total.
data AmbiguousNameReason

-- | The name resolves both to a local variable and some declared names.
AmbiguousLocalVar :: LocalVar -> List1 AbstractName -> AmbiguousNameReason

-- | The name resolves to at least 2 declared names.
AmbiguousDeclName :: List2 AbstractName -> AmbiguousNameReason

-- | The flat list of ambiguous names in <a>AmbiguousNameReason</a>.
ambiguousNamesInReason :: AmbiguousNameReason -> List2 QName
data WhyInScopeData
WhyInScopeData :: QName -> FilePath -> Maybe LocalVar -> [AbstractName] -> [AbstractModule] -> WhyInScopeData
whyInScopeDataFromAmbiguousNameReason :: QName -> AmbiguousNameReason -> WhyInScopeData
mergeNames :: Eq a => ThingsInScope a -> ThingsInScope a -> ThingsInScope a
mergeNamesMany :: Eq a => [ThingsInScope a] -> ThingsInScope a

-- | The empty name space.
emptyNameSpace :: NameSpace

-- | Map functions over the names and modules in a name space.
mapNameSpace :: (NamesInScope -> NamesInScope) -> (ModulesInScope -> ModulesInScope) -> (InScopeSet -> InScopeSet) -> NameSpace -> NameSpace

-- | Zip together two name spaces.
zipNameSpace :: (NamesInScope -> NamesInScope -> NamesInScope) -> (ModulesInScope -> ModulesInScope -> ModulesInScope) -> (InScopeSet -> InScopeSet -> InScopeSet) -> NameSpace -> NameSpace -> NameSpace

-- | Map monadic function over a namespace.
mapNameSpaceM :: Applicative m => (NamesInScope -> m NamesInScope) -> (ModulesInScope -> m ModulesInScope) -> (InScopeSet -> m InScopeSet) -> NameSpace -> m NameSpace

-- | The empty scope.
emptyScope :: Scope

-- | The empty scope info.
emptyScopeInfo :: ScopeInfo

-- | Map functions over the names and modules in a scope.
mapScope :: (NameSpaceId -> NamesInScope -> NamesInScope) -> (NameSpaceId -> ModulesInScope -> ModulesInScope) -> (NameSpaceId -> InScopeSet -> InScopeSet) -> Scope -> Scope

-- | Same as <a>mapScope</a> but applies the same function to all name
--   spaces.
mapScope_ :: (NamesInScope -> NamesInScope) -> (ModulesInScope -> ModulesInScope) -> (InScopeSet -> InScopeSet) -> Scope -> Scope

-- | Same as <a>mapScope</a> but applies the function only on the given
--   name space.
mapScopeNS :: NameSpaceId -> (NamesInScope -> NamesInScope) -> (ModulesInScope -> ModulesInScope) -> (InScopeSet -> InScopeSet) -> Scope -> Scope

-- | Map monadic functions over the names and modules in a scope.
mapScopeM :: Applicative m => (NameSpaceId -> NamesInScope -> m NamesInScope) -> (NameSpaceId -> ModulesInScope -> m ModulesInScope) -> (NameSpaceId -> InScopeSet -> m InScopeSet) -> Scope -> m Scope

-- | Same as <a>mapScopeM</a> but applies the same function to both the
--   public and private name spaces.
mapScopeM_ :: Applicative m => (NamesInScope -> m NamesInScope) -> (ModulesInScope -> m ModulesInScope) -> (InScopeSet -> m InScopeSet) -> Scope -> m Scope

-- | Zip together two scopes. The resulting scope has the same name as the
--   first scope.
zipScope :: (NameSpaceId -> NamesInScope -> NamesInScope -> NamesInScope) -> (NameSpaceId -> ModulesInScope -> ModulesInScope -> ModulesInScope) -> (NameSpaceId -> InScopeSet -> InScopeSet -> InScopeSet) -> Scope -> Scope -> Scope

-- | Same as <a>zipScope</a> but applies the same function to both the
--   public and private name spaces.
zipScope_ :: (NamesInScope -> NamesInScope -> NamesInScope) -> (ModulesInScope -> ModulesInScope -> ModulesInScope) -> (InScopeSet -> InScopeSet -> InScopeSet) -> Scope -> Scope -> Scope

-- | Recompute the inScope sets of a scope.
recomputeInScopeSets :: Scope -> Scope

-- | Filter a scope keeping only concrete names matching the predicates.
--   The first predicate is applied to the names and the second to the
--   modules.
filterScope :: (Name -> Bool) -> (Name -> Bool) -> Scope -> Scope

-- | Return all names in a scope.
allNamesInScope :: InScope a => Scope -> ThingsInScope a
allNamesInScope' :: InScope a => Scope -> ThingsInScope (a, Access)

-- | Look up a single name in the current scope.
--   
--   This is equivalent to <tt>Map.lookup n . allNamesInScope'</tt>, but
--   more efficient when only a single name needs to be looked up.
findNameInScope :: InScope a => Name -> Scope -> [(a, Access)]

-- | Returns the scope's non-private names.
exportedNamesInScope :: InScope a => Scope -> ThingsInScope a
namesInScope :: InScope a => [NameSpaceId] -> Scope -> ThingsInScope a
allThingsInScope :: Scope -> NameSpace
thingsInScope :: [NameSpaceId] -> Scope -> NameSpace

-- | Merge two scopes. The result has the name of the first scope.
mergeScope :: Scope -> Scope -> Scope

-- | Merge a non-empty list of scopes. The result has the name of the first
--   scope in the list.
mergeScopes :: [Scope] -> Scope

-- | Move all names in a scope to the given name space (except never move
--   from Imported to Public).
setScopeAccess :: NameSpaceId -> Scope -> Scope

-- | Update a particular name space.
setNameSpace :: NameSpaceId -> NameSpace -> Scope -> Scope

-- | Modify a particular name space.
modifyNameSpace :: NameSpaceId -> (NameSpace -> NameSpace) -> Scope -> Scope

-- | Add a name to a scope.
addNameToScope :: NameSpaceId -> Name -> AbstractName -> Scope -> Scope

-- | Remove a name from a scope. Caution: does not update the nsInScope
--   set. This is only used by rebindName and in that case we add the name
--   right back (but with a different kind).
removeNameFromScope :: NameSpaceId -> Name -> Scope -> Scope

-- | Add a module to a scope.
addModuleToScope :: NameSpaceId -> Name -> AbstractModule -> Scope -> Scope

-- | When we get here we cannot have both <tt>using</tt> and
--   <tt>hiding</tt>.
data UsingOrHiding
UsingOnly :: [ImportedName] -> UsingOrHiding
HidingOnly :: [ImportedName] -> UsingOrHiding
usingOrHiding :: ImportDirective -> UsingOrHiding

-- | Apply an <a>ImportDirective</a> to a scope:
--   
--   <ol>
--   <li>rename keys (C.Name) according to <tt>renaming</tt>;</li>
--   <li>for untouched keys, either of</li>
--   </ol>
--   
--   a) remove keys according to <tt>hiding</tt>, or b) filter keys
--   according to <tt>using</tt>.
--   
--   Both steps could be done in one pass, by first preparing key-filtering
--   functions <tt>C.Name -&gt; Maybe C.Name</tt> for defined names and
--   module names. However, the penalty of doing it in two passes should
--   not be too high. (Doubling the run time.)
applyImportDirective :: ImportDirective -> Scope -> Scope

-- | Version of <a>applyImportDirective</a> that also returns sets of name
--   and module name clashes introduced by <tt>renaming</tt> to identifiers
--   that are already imported by <tt>using</tt> or lack of
--   <tt>hiding</tt>.
applyImportDirective_ :: ImportDirective -> Scope -> (Scope, (Set Name, Set Name))

-- | Rename the abstract names in a scope.
renameCanonicalNames :: Map QName QName -> Map ModuleName ModuleName -> Scope -> Scope

-- | Remove private name space of a scope.
--   
--   Should be a right identity for <a>exportedNamesInScope</a>.
--   <tt>exportedNamesInScope . restrictPrivate ==
--   exportedNamesInScope</tt>.
restrictPrivate :: Scope -> Scope

-- | Remove private things from the given module from a scope.
restrictLocalPrivate :: ModuleName -> Scope -> Scope

-- | Filter privates out of a <a>ScopeInfo</a>
withoutPrivates :: ScopeInfo -> ScopeInfo

-- | Disallow using generalized variables from the scope
disallowGeneralizedVars :: Scope -> Scope

-- | Add an explanation to why things are in scope.
inScopeBecause :: (WhyInScope -> WhyInScope) -> Scope -> Scope

-- | Get the public parts of the public modules of a scope
publicModules :: ScopeInfo -> Map ModuleName Scope
publicNames :: ScopeInfo -> Set AbstractName
publicNamesOfModules :: Map ModuleName Scope -> [AbstractName]
everythingInScope :: ScopeInfo -> NameSpace
everythingInScopeQualified :: ScopeInfo -> NameSpace

-- | Get all concrete names in scope. Includes bound variables.
concreteNamesInScope :: ScopeInfo -> Set QName

-- | Look up a name in the scope
scopeLookup :: InScope a => QName -> ScopeInfo -> [a]
scopeLookup' :: forall a. InScope a => QName -> ScopeInfo -> [(a, Access)]
data AllowAmbiguousNames

-- | Used for instance arguments to check whether a name is in scope, but
--   we do not care whether is is ambiguous
AmbiguousAnything :: AllowAmbiguousNames

-- | Ambiguous constructors, projections, or pattern synonyms.
AmbiguousConProjs :: AllowAmbiguousNames
AmbiguousNothing :: AllowAmbiguousNames
isNameInScope :: QName -> ScopeInfo -> Bool
isNameInScopeUnqualified :: QName -> ScopeInfo -> Bool

-- | Find the concrete names that map (uniquely) to a given abstract
--   qualified name. Sort by number of modules in the qualified name,
--   unqualified names first.
inverseScopeLookupName :: QName -> ScopeInfo -> [QName]
inverseScopeLookupName' :: AllowAmbiguousNames -> QName -> ScopeInfo -> [QName]

-- | A version of <a>inverseScopeLookupName</a> that also delivers the
--   <a>KindOfName</a>. Used in highlighting.
inverseScopeLookupName'' :: AllowAmbiguousNames -> QName -> ScopeInfo -> Maybe NameMapEntry

-- | Find the concrete names that map (uniquely) to a given abstract module
--   name. Sort by length, shortest first.
inverseScopeLookupModule :: ModuleName -> ScopeInfo -> [QName]
inverseScopeLookupModule' :: AllowAmbiguousNames -> ModuleName -> ScopeInfo -> [QName]
recomputeInverseScopeMaps :: ScopeInfo -> ScopeInfo

-- | Set the <a>nameBindingSite</a> in an abstract name.
class SetBindingSite a
setBindingSite :: SetBindingSite a => Range -> a -> a
setBindingSite :: (SetBindingSite a, SetBindingSite b, Functor t, t b ~ a) => Range -> a -> a
prettyNameSpace :: NameSpace -> [Doc]

-- | Add first string only if list is non-empty.
blockOfLines :: Doc -> [Doc] -> [Doc]
instance GHC.Generics.Generic Agda.Syntax.Scope.Base.DataOrRecordModule
instance GHC.Enum.Bounded Agda.Syntax.Scope.Base.DataOrRecordModule
instance GHC.Enum.Enum Agda.Syntax.Scope.Base.DataOrRecordModule
instance GHC.Classes.Eq Agda.Syntax.Scope.Base.DataOrRecordModule
instance GHC.Show.Show Agda.Syntax.Scope.Base.DataOrRecordModule
instance GHC.Generics.Generic Agda.Syntax.Scope.Base.NameSpaceId
instance GHC.Show.Show Agda.Syntax.Scope.Base.NameSpaceId
instance GHC.Enum.Enum Agda.Syntax.Scope.Base.NameSpaceId
instance GHC.Enum.Bounded Agda.Syntax.Scope.Base.NameSpaceId
instance GHC.Classes.Eq Agda.Syntax.Scope.Base.NameSpaceId
instance GHC.Generics.Generic Agda.Syntax.Scope.Base.BindingSource
instance GHC.Classes.Eq Agda.Syntax.Scope.Base.BindingSource
instance GHC.Show.Show Agda.Syntax.Scope.Base.BindingSource
instance GHC.Generics.Generic Agda.Syntax.Scope.Base.NameOrModule
instance GHC.Enum.Bounded Agda.Syntax.Scope.Base.NameOrModule
instance GHC.Enum.Enum Agda.Syntax.Scope.Base.NameOrModule
instance GHC.Show.Show Agda.Syntax.Scope.Base.NameOrModule
instance GHC.Classes.Ord Agda.Syntax.Scope.Base.NameOrModule
instance GHC.Classes.Eq Agda.Syntax.Scope.Base.NameOrModule
instance GHC.Generics.Generic Agda.Syntax.Scope.Base.KindOfName
instance GHC.Enum.Bounded Agda.Syntax.Scope.Base.KindOfName
instance GHC.Enum.Enum Agda.Syntax.Scope.Base.KindOfName
instance GHC.Show.Show Agda.Syntax.Scope.Base.KindOfName
instance GHC.Classes.Ord Agda.Syntax.Scope.Base.KindOfName
instance GHC.Classes.Eq Agda.Syntax.Scope.Base.KindOfName
instance GHC.Generics.Generic Agda.Syntax.Scope.Base.NameMapEntry
instance GHC.Show.Show Agda.Syntax.Scope.Base.NameMapEntry
instance Data.Traversable.Traversable Agda.Syntax.Scope.Base.WithKind
instance Data.Foldable.Foldable Agda.Syntax.Scope.Base.WithKind
instance GHC.Base.Functor Agda.Syntax.Scope.Base.WithKind
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.Syntax.Scope.Base.WithKind a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Scope.Base.WithKind a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Scope.Base.WithKind a)
instance GHC.Generics.Generic Agda.Syntax.Scope.Base.WhyInScope
instance GHC.Show.Show Agda.Syntax.Scope.Base.WhyInScope
instance GHC.Generics.Generic Agda.Syntax.Scope.Base.NameMetadata
instance GHC.Show.Show Agda.Syntax.Scope.Base.NameMetadata
instance GHC.Generics.Generic Agda.Syntax.Scope.Base.AbstractName
instance GHC.Show.Show Agda.Syntax.Scope.Base.AbstractName
instance GHC.Generics.Generic Agda.Syntax.Scope.Base.LocalVar
instance GHC.Show.Show Agda.Syntax.Scope.Base.LocalVar
instance GHC.Generics.Generic Agda.Syntax.Scope.Base.AbstractModule
instance GHC.Show.Show Agda.Syntax.Scope.Base.AbstractModule
instance GHC.Generics.Generic Agda.Syntax.Scope.Base.NameSpace
instance GHC.Show.Show Agda.Syntax.Scope.Base.NameSpace
instance GHC.Classes.Eq Agda.Syntax.Scope.Base.NameSpace
instance GHC.Generics.Generic Agda.Syntax.Scope.Base.Scope
instance GHC.Show.Show Agda.Syntax.Scope.Base.Scope
instance GHC.Classes.Eq Agda.Syntax.Scope.Base.Scope
instance GHC.Generics.Generic Agda.Syntax.Scope.Base.ScopeInfo
instance GHC.Show.Show Agda.Syntax.Scope.Base.ScopeInfo
instance GHC.Generics.Generic Agda.Syntax.Scope.Base.ResolvedName
instance GHC.Classes.Eq Agda.Syntax.Scope.Base.ResolvedName
instance GHC.Show.Show Agda.Syntax.Scope.Base.ResolvedName
instance GHC.Generics.Generic Agda.Syntax.Scope.Base.AmbiguousNameReason
instance GHC.Show.Show Agda.Syntax.Scope.Base.AmbiguousNameReason
instance GHC.Classes.Eq Agda.Syntax.Scope.Base.AllowAmbiguousNames
instance Agda.Syntax.Scope.Base.SetBindingSite a => Agda.Syntax.Scope.Base.SetBindingSite [a]
instance Agda.Syntax.Scope.Base.SetBindingSite a => Agda.Syntax.Scope.Base.SetBindingSite (Agda.Utils.List1.List1 a)
instance Agda.Syntax.Scope.Base.SetBindingSite Agda.Syntax.Abstract.Name.Name
instance Agda.Syntax.Scope.Base.SetBindingSite Agda.Syntax.Abstract.Name.QName
instance Agda.Syntax.Scope.Base.SetBindingSite Agda.Syntax.Abstract.Name.ModuleName
instance Agda.Syntax.Scope.Base.SetBindingSite Agda.Syntax.Scope.Base.AbstractName
instance Agda.Syntax.Scope.Base.SetBindingSite Agda.Syntax.Scope.Base.AbstractModule
instance Control.DeepSeq.NFData Agda.Syntax.Scope.Base.AmbiguousNameReason
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Scope.Base.ResolvedName
instance Control.DeepSeq.NFData Agda.Syntax.Scope.Base.ResolvedName
instance GHC.Classes.Eq Agda.Syntax.Scope.Base.ScopeInfo
instance Agda.Utils.Null.Null Agda.Syntax.Scope.Base.ScopeInfo
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Scope.Base.ScopeInfo
instance Agda.Syntax.Position.KillRange Agda.Syntax.Scope.Base.ScopeInfo
instance Control.DeepSeq.NFData Agda.Syntax.Scope.Base.ScopeInfo
instance Agda.Utils.Null.Null Agda.Syntax.Scope.Base.Scope
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Scope.Base.Scope
instance Control.DeepSeq.NFData Agda.Syntax.Scope.Base.Scope
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Scope.Base.NameSpace
instance Control.DeepSeq.NFData Agda.Syntax.Scope.Base.NameSpace
instance Agda.Syntax.Scope.Base.InScope Agda.Syntax.Scope.Base.AbstractName
instance Agda.Syntax.Scope.Base.InScope Agda.Syntax.Scope.Base.AbstractModule
instance GHC.Classes.Eq Agda.Syntax.Scope.Base.AbstractModule
instance GHC.Classes.Ord Agda.Syntax.Scope.Base.AbstractModule
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Scope.Base.AbstractModule
instance Control.DeepSeq.NFData Agda.Syntax.Scope.Base.AbstractModule
instance GHC.Classes.Eq Agda.Syntax.Scope.Base.LocalVar
instance GHC.Classes.Ord Agda.Syntax.Scope.Base.LocalVar
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Scope.Base.LocalVar
instance Control.DeepSeq.NFData Agda.Syntax.Scope.Base.LocalVar
instance GHC.Classes.Eq Agda.Syntax.Scope.Base.AbstractName
instance GHC.Classes.Ord Agda.Syntax.Scope.Base.AbstractName
instance Agda.Syntax.Common.LensFixity Agda.Syntax.Scope.Base.AbstractName
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Scope.Base.AbstractName
instance Agda.Syntax.Position.HasRange Agda.Syntax.Scope.Base.AbstractName
instance Agda.Syntax.Position.SetRange Agda.Syntax.Scope.Base.AbstractName
instance Control.DeepSeq.NFData Agda.Syntax.Scope.Base.AbstractName
instance Control.DeepSeq.NFData Agda.Syntax.Scope.Base.NameMetadata
instance Control.DeepSeq.NFData Agda.Syntax.Scope.Base.WhyInScope
instance GHC.Base.Semigroup Agda.Syntax.Scope.Base.NameMapEntry
instance Control.DeepSeq.NFData Agda.Syntax.Scope.Base.NameMapEntry
instance Control.DeepSeq.NFData Agda.Syntax.Scope.Base.KindOfName
instance Control.DeepSeq.NFData Agda.Syntax.Scope.Base.NameOrModule
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Scope.Base.BindingSource
instance Control.DeepSeq.NFData Agda.Syntax.Scope.Base.BindingSource
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Scope.Base.NameSpaceId
instance Control.DeepSeq.NFData Agda.Syntax.Scope.Base.NameSpaceId
instance Control.DeepSeq.NFData Agda.Syntax.Scope.Base.DataOrRecordModule
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Abstract.Name.Suffix


-- | An info object contains additional information about a piece of
--   abstract syntax that isn't part of the actual syntax. For instance, it
--   might contain the source code position of an expression or the
--   concrete syntax that an internal expression originates from.
module Agda.Syntax.Info

-- | Kind of a meta: the method how to solve it.
data MetaKind

-- | Meta variable solved by instance search.
InstanceMeta :: MetaKind

-- | Meta variable solved by unification (default).
UnificationMeta :: MetaKind

-- | Default meta kind from its <a>Hiding</a> context.
hidingToMetaKind :: Hiding -> MetaKind

-- | Name suggestion for meta variable. Empty string means no suggestion.
type MetaNameSuggestion = String

-- | Information associated to a meta variable in the abstract syntax.
data MetaInfo
MetaInfo :: Range -> ScopeInfo -> Maybe MetaId -> MetaNameSuggestion -> MetaKind -> MetaInfo
[metaRange] :: MetaInfo -> Range
[metaScope] :: MetaInfo -> ScopeInfo
[metaNumber] :: MetaInfo -> Maybe MetaId
[metaNameSuggestion] :: MetaInfo -> MetaNameSuggestion
[metaKind] :: MetaInfo -> MetaKind
emptyMetaInfo :: MetaInfo
newtype ExprInfo
ExprRange :: Range -> ExprInfo
exprNoRange :: ExprInfo

-- | Information about application
data AppInfo
AppInfo :: Range -> Origin -> ParenPreference -> AppInfo
[appRange] :: AppInfo -> Range
[appOrigin] :: AppInfo -> Origin

-- | Do we prefer a lambda argument with or without parens?
[appParens] :: AppInfo -> ParenPreference

-- | Default is system inserted and prefer parens.
defaultAppInfo :: Range -> AppInfo

-- | <a>AppInfo</a> with no range information.
defaultAppInfo_ :: AppInfo
data ModuleInfo
ModuleInfo :: Range -> Range -> Maybe Name -> Maybe OpenShortHand -> Maybe ImportDirective -> ModuleInfo
[minfoRange] :: ModuleInfo -> Range

-- | The range of the "as" and "to" keywords, if any. Retained for
--   highlighting purposes.
[minfoAsTo] :: ModuleInfo -> Range

-- | The "as" module name, if any. Retained for highlighting purposes.
[minfoAsName] :: ModuleInfo -> Maybe Name
[minfoOpenShort] :: ModuleInfo -> Maybe OpenShortHand

-- | Retained for <tt>abstractToConcrete</tt> of <a>ModuleMacro</a>.
[minfoDirective] :: ModuleInfo -> Maybe ImportDirective
newtype LetInfo
LetRange :: Range -> LetInfo
data DefInfo' t
DefInfo :: Fixity' -> Access -> IsAbstract -> IsOpaque -> IsInstance -> IsMacro -> DeclInfo -> TacticAttribute' t -> DefInfo' t
[defFixity] :: DefInfo' t -> Fixity'
[defAccess] :: DefInfo' t -> Access
[defAbstract] :: DefInfo' t -> IsAbstract
[defOpaque] :: DefInfo' t -> IsOpaque
[defInstance] :: DefInfo' t -> IsInstance
[defMacro] :: DefInfo' t -> IsMacro
[defInfo] :: DefInfo' t -> DeclInfo
[defTactic] :: DefInfo' t -> TacticAttribute' t
mkDefInfo :: Name -> Fixity' -> Access -> IsAbstract -> Range -> DefInfo' t

-- | Same as <tt>mkDefInfo</tt> but where we can also give the
--   <tt>IsInstance</tt>
mkDefInfoInstance :: Name -> Fixity' -> Access -> IsAbstract -> IsInstance -> IsMacro -> Range -> DefInfo' t
data DeclInfo
DeclInfo :: Name -> Range -> DeclInfo
[declName] :: DeclInfo -> Name
[declRange] :: DeclInfo -> Range
data MutualInfo
MutualInfo :: TerminationCheck Name -> CoverageCheck -> PositivityCheck -> Range -> MutualInfo
[mutualTerminationCheck] :: MutualInfo -> TerminationCheck Name
[mutualCoverageCheck] :: MutualInfo -> CoverageCheck
[mutualPositivityCheck] :: MutualInfo -> PositivityCheck
[mutualRange] :: MutualInfo -> Range
data LHSInfo
LHSInfo :: Range -> ExpandedEllipsis -> LHSInfo
[lhsRange] :: LHSInfo -> Range
[lhsEllipsis] :: LHSInfo -> ExpandedEllipsis

-- | For a general pattern we remember the source code position.
newtype PatInfo
PatRange :: Range -> PatInfo

-- | Empty range for patterns.
patNoRange :: PatInfo

-- | Constructor pattern info.
data ConPatInfo
ConPatInfo :: ConOrigin -> PatInfo -> ConPatLazy -> ConPatInfo

-- | Does this pattern come form the eta-expansion of an implicit pattern?
[conPatOrigin] :: ConPatInfo -> ConOrigin
[conPatInfo] :: ConPatInfo -> PatInfo
[conPatLazy] :: ConPatInfo -> ConPatLazy

-- | Has the constructor pattern a dotted (forced) constructor?
data ConPatLazy

-- | Dotted constructor.
ConPatLazy :: ConPatLazy

-- | Ordinary constructor.
ConPatEager :: ConPatLazy
instance GHC.Generics.Generic Agda.Syntax.Info.MetaKind
instance GHC.Classes.Eq Agda.Syntax.Info.MetaKind
instance GHC.Show.Show Agda.Syntax.Info.MetaKind
instance GHC.Generics.Generic Agda.Syntax.Info.MetaInfo
instance GHC.Classes.Eq Agda.Syntax.Info.MetaInfo
instance GHC.Show.Show Agda.Syntax.Info.MetaInfo
instance Control.DeepSeq.NFData Agda.Syntax.Info.ExprInfo
instance Agda.Utils.Null.Null Agda.Syntax.Info.ExprInfo
instance GHC.Classes.Eq Agda.Syntax.Info.ExprInfo
instance GHC.Show.Show Agda.Syntax.Info.ExprInfo
instance GHC.Generics.Generic Agda.Syntax.Info.AppInfo
instance GHC.Classes.Ord Agda.Syntax.Info.AppInfo
instance GHC.Classes.Eq Agda.Syntax.Info.AppInfo
instance GHC.Show.Show Agda.Syntax.Info.AppInfo
instance GHC.Generics.Generic Agda.Syntax.Info.ModuleInfo
instance GHC.Show.Show Agda.Syntax.Info.ModuleInfo
instance GHC.Classes.Eq Agda.Syntax.Info.ModuleInfo
instance Control.DeepSeq.NFData Agda.Syntax.Info.LetInfo
instance Agda.Utils.Null.Null Agda.Syntax.Info.LetInfo
instance GHC.Classes.Eq Agda.Syntax.Info.LetInfo
instance GHC.Show.Show Agda.Syntax.Info.LetInfo
instance GHC.Generics.Generic Agda.Syntax.Info.DeclInfo
instance GHC.Classes.Eq Agda.Syntax.Info.DeclInfo
instance GHC.Show.Show Agda.Syntax.Info.DeclInfo
instance GHC.Generics.Generic (Agda.Syntax.Info.DefInfo' t)
instance GHC.Classes.Eq t => GHC.Classes.Eq (Agda.Syntax.Info.DefInfo' t)
instance GHC.Show.Show t => GHC.Show.Show (Agda.Syntax.Info.DefInfo' t)
instance GHC.Generics.Generic Agda.Syntax.Info.MutualInfo
instance GHC.Classes.Eq Agda.Syntax.Info.MutualInfo
instance GHC.Show.Show Agda.Syntax.Info.MutualInfo
instance GHC.Generics.Generic Agda.Syntax.Info.LHSInfo
instance GHC.Classes.Eq Agda.Syntax.Info.LHSInfo
instance GHC.Show.Show Agda.Syntax.Info.LHSInfo
instance Control.DeepSeq.NFData Agda.Syntax.Info.PatInfo
instance Agda.Syntax.Position.KillRange Agda.Syntax.Info.PatInfo
instance Agda.Syntax.Position.HasRange Agda.Syntax.Info.PatInfo
instance Agda.Syntax.Position.SetRange Agda.Syntax.Info.PatInfo
instance GHC.Show.Show Agda.Syntax.Info.PatInfo
instance GHC.Base.Monoid Agda.Syntax.Info.PatInfo
instance GHC.Base.Semigroup Agda.Syntax.Info.PatInfo
instance Agda.Utils.Null.Null Agda.Syntax.Info.PatInfo
instance GHC.Classes.Eq Agda.Syntax.Info.PatInfo
instance GHC.Generics.Generic Agda.Syntax.Info.ConPatLazy
instance GHC.Enum.Enum Agda.Syntax.Info.ConPatLazy
instance GHC.Enum.Bounded Agda.Syntax.Info.ConPatLazy
instance GHC.Show.Show Agda.Syntax.Info.ConPatLazy
instance GHC.Classes.Ord Agda.Syntax.Info.ConPatLazy
instance GHC.Classes.Eq Agda.Syntax.Info.ConPatLazy
instance GHC.Generics.Generic Agda.Syntax.Info.ConPatInfo
instance GHC.Show.Show Agda.Syntax.Info.ConPatInfo
instance GHC.Classes.Eq Agda.Syntax.Info.ConPatInfo
instance Agda.Syntax.Position.HasRange Agda.Syntax.Info.ConPatInfo
instance Agda.Syntax.Position.KillRange Agda.Syntax.Info.ConPatInfo
instance Agda.Syntax.Position.SetRange Agda.Syntax.Info.ConPatInfo
instance Control.DeepSeq.NFData Agda.Syntax.Info.ConPatInfo
instance Control.DeepSeq.NFData Agda.Syntax.Info.ConPatLazy
instance Agda.Syntax.Position.HasRange Agda.Syntax.Info.LHSInfo
instance Agda.Syntax.Position.KillRange Agda.Syntax.Info.LHSInfo
instance Agda.Utils.Null.Null Agda.Syntax.Info.LHSInfo
instance Control.DeepSeq.NFData Agda.Syntax.Info.LHSInfo
instance Agda.Utils.Null.Null Agda.Syntax.Info.MutualInfo
instance Agda.Syntax.Position.HasRange Agda.Syntax.Info.MutualInfo
instance Agda.Syntax.Position.KillRange Agda.Syntax.Info.MutualInfo
instance Control.DeepSeq.NFData Agda.Syntax.Info.MutualInfo
instance Agda.Syntax.Position.HasRange (Agda.Syntax.Info.DefInfo' t)
instance Agda.Syntax.Position.SetRange (Agda.Syntax.Info.DefInfo' t)
instance Agda.Syntax.Position.KillRange t => Agda.Syntax.Position.KillRange (Agda.Syntax.Info.DefInfo' t)
instance Agda.Syntax.Common.LensIsAbstract (Agda.Syntax.Info.DefInfo' t)
instance Agda.Syntax.Common.LensIsOpaque (Agda.Syntax.Info.DefInfo' t)
instance Agda.Syntax.Common.AnyIsAbstract (Agda.Syntax.Info.DefInfo' t)
instance Agda.Syntax.Common.AllAreOpaque (Agda.Syntax.Info.DefInfo' t)
instance Control.DeepSeq.NFData t => Control.DeepSeq.NFData (Agda.Syntax.Info.DefInfo' t)
instance Agda.Syntax.Position.HasRange Agda.Syntax.Info.DeclInfo
instance Agda.Syntax.Position.SetRange Agda.Syntax.Info.DeclInfo
instance Agda.Syntax.Position.KillRange Agda.Syntax.Info.DeclInfo
instance Control.DeepSeq.NFData Agda.Syntax.Info.DeclInfo
instance Agda.Syntax.Position.HasRange Agda.Syntax.Info.LetInfo
instance Agda.Syntax.Position.KillRange Agda.Syntax.Info.LetInfo
instance Agda.Syntax.Position.HasRange Agda.Syntax.Info.ModuleInfo
instance Agda.Syntax.Position.SetRange Agda.Syntax.Info.ModuleInfo
instance Agda.Syntax.Position.KillRange Agda.Syntax.Info.ModuleInfo
instance Control.DeepSeq.NFData Agda.Syntax.Info.ModuleInfo
instance Agda.Syntax.Position.HasRange Agda.Syntax.Info.AppInfo
instance Agda.Syntax.Position.KillRange Agda.Syntax.Info.AppInfo
instance Agda.Syntax.Common.LensOrigin Agda.Syntax.Info.AppInfo
instance Control.DeepSeq.NFData Agda.Syntax.Info.AppInfo
instance Agda.Syntax.Position.HasRange Agda.Syntax.Info.ExprInfo
instance Agda.Syntax.Position.KillRange Agda.Syntax.Info.ExprInfo
instance Agda.Utils.Null.Null Agda.Syntax.Info.MetaInfo
instance Agda.Syntax.Position.HasRange Agda.Syntax.Info.MetaInfo
instance Agda.Syntax.Position.KillRange Agda.Syntax.Info.MetaInfo
instance Control.DeepSeq.NFData Agda.Syntax.Info.MetaInfo
instance Agda.Utils.Null.Null Agda.Syntax.Info.MetaKind
instance Control.DeepSeq.NFData Agda.Syntax.Info.MetaKind


-- | The abstract syntax. This is what you get after desugaring and scope
--   analysis of the concrete syntax. The type checker works on abstract
--   syntax, producing internal syntax (<a>Agda.Syntax.Internal</a>).
module Agda.Syntax.Abstract
type Args = [NamedArg Expr]

-- | Types are just expressions. Use this type synonym for hinting that an
--   expression should be a type.
type Type = Expr
type Constructor = TypeSignature
type Clause = Clause' LHS
type Pattern = Pattern' Expr
data Pragma
OptionsPragma :: [String] -> Pragma

-- | <a>ResolvedName</a> is not <a>UnknownName</a>. Name can be ambiguous
--   e.g. for built-in constructors.
BuiltinPragma :: RString -> ResolvedName -> Pragma

-- | Builtins that do not come with a definition, but declare a name for an
--   Agda concept.
BuiltinNoDefPragma :: RString -> KindOfName -> QName -> Pragma

-- | Range is range of REWRITE keyword.
RewritePragma :: Range -> [QName] -> Pragma
CompilePragma :: RString -> QName -> String -> Pragma
StaticPragma :: QName -> Pragma

-- | For coinductive records, use pragma instead of regular
--   <tt>eta-equality</tt> definition (as it is might make Agda loop).
EtaPragma :: QName -> Pragma
InjectivePragma :: QName -> Pragma
InjectiveForInferencePragma :: QName -> Pragma
InlinePragma :: Bool -> QName -> Pragma

-- | Mark the definition as not being projection-like
NotProjectionLikePragma :: QName -> Pragma

-- | If the definition is an instance, set its overlap mode.
OverlapPragma :: QName -> OverlapMode -> Pragma
DisplayPragma :: QName -> [NamedArg Pattern] -> Expr -> Pragma
type Telescope = [TypedBinding]

-- | Record field assignment <tt>f = e</tt>.
type Assign = FieldAssignment' Expr

-- | Expressions after scope checking (operators parsed, names resolved).
data Expr

-- | Bound variable.
Var :: Name -> Expr

-- | Constant: axiom, function, data or record type, with a possible
--   suffix.
Def' :: QName -> Suffix -> Expr

-- | Projection (overloaded).
Proj :: ProjOrigin -> AmbiguousQName -> Expr

-- | Constructor (overloaded).
Con :: AmbiguousQName -> Expr

-- | Pattern synonym.
PatternSyn :: AmbiguousQName -> Expr

-- | Macro.
Macro :: QName -> Expr

-- | Literal.
Lit :: ExprInfo -> Literal -> Expr

-- | Meta variable for interaction. The <a>InteractionId</a> is usually
--   identical with the <a>metaNumber</a> of <a>MetaInfo</a>. However, if
--   you want to print an interaction meta as just <tt>?</tt> instead of
--   <tt>?n</tt>, you should set the <a>metaNumber</a> to <a>Nothing</a>
--   while keeping the <a>InteractionId</a>.
QuestionMark :: MetaInfo -> InteractionId -> Expr

-- | Meta variable for hidden argument (must be inferred locally).
Underscore :: MetaInfo -> Expr

-- | <tt>.e</tt>, for postfix projection.
Dot :: ExprInfo -> Expr -> Expr

-- | Ordinary (binary) application.
App :: AppInfo -> Expr -> NamedArg Expr -> Expr

-- | With application.
WithApp :: ExprInfo -> Expr -> [Expr] -> Expr

-- | <tt>λ bs → e</tt>.
Lam :: ExprInfo -> LamBinding -> Expr -> Expr

-- | <tt>λ()</tt> or <tt>λ{}</tt>.
AbsurdLam :: ExprInfo -> Hiding -> Expr
ExtendedLam :: ExprInfo -> DefInfo -> Erased -> QName -> List1 Clause -> Expr

-- | Dependent function space <tt>Γ → A</tt>.
Pi :: ExprInfo -> Telescope1 -> Type -> Expr

-- | Like a Pi, but the ordering is not known
Generalized :: Set QName -> Type -> Expr

-- | Non-dependent function space.
Fun :: ExprInfo -> Arg Type -> Type -> Expr

-- | <tt>let bs in e</tt>.
Let :: ExprInfo -> List1 LetBinding -> Expr -> Expr

-- | Record construction.
Rec :: ExprInfo -> RecordAssigns -> Expr

-- | Record update.
RecUpdate :: ExprInfo -> Expr -> Assigns -> Expr

-- | Scope annotation.
ScopedExpr :: ScopeInfo -> Expr -> Expr

-- | Quote an identifier <a>QName</a>.
Quote :: ExprInfo -> Expr

-- | Quote a term.
QuoteTerm :: ExprInfo -> Expr

-- | The splicing construct: unquote ...
Unquote :: ExprInfo -> Expr

-- | For printing <tt>DontCare</tt> from <tt>Syntax.Internal</tt>.
DontCare :: Expr -> Expr

-- | The lhs of a clause in focused (projection-application) view
--   (outside-in). Projection patters are represented as <a>LHSProj</a>s.
data LHS
LHS :: LHSInfo -> LHSCore -> LHS

-- | Range.
[lhsInfo] :: LHS -> LHSInfo

-- | Copatterns.
[lhsCore] :: LHS -> LHSCore
type TacticAttribute = TacticAttribute' Expr
data Binder' a
Binder :: Maybe Pattern -> a -> Binder' a
[binderPattern] :: Binder' a -> Maybe Pattern
[binderName] :: Binder' a -> a
type Binder = Binder' BindName

-- | A lambda binding is either domain free or typed.
data LamBinding

-- | . <tt>x</tt> or <tt>{x}</tt> or <tt>.x</tt> or <tt>{x = y}</tt> or
--   <tt>x@p</tt> or <tt>(p)</tt>
DomainFree :: TacticAttribute -> NamedArg Binder -> LamBinding

-- | . <tt>(xs:e)</tt> or <tt>{xs:e}</tt> or <tt>(let Ds)</tt>
DomainFull :: TypedBinding -> LamBinding

-- | A typed binding. Appears in dependent function spaces, typed lambdas,
--   and telescopes. It might be tempting to simplify this to only bind a
--   single name at a time, and translate, say, <tt>(x y : A)</tt> to
--   <tt>(x : A)(y : A)</tt> before type-checking. However, this would be
--   slightly problematic:
--   
--   <ol>
--   <li>We would have to typecheck the type <tt>A</tt> several times.</li>
--   <li>If <tt>A</tt> contains a meta variable or hole, it would be
--   duplicated by such a translation.</li>
--   </ol>
--   
--   While 1. is only slightly inefficient, 2. would be an outright bug.
--   Duplicating <tt>A</tt> could not be done naively, we would have to
--   make sure that the metas of the copy are aliases of the metas of the
--   original.
data TypedBinding

-- | As in telescope <tt>(x y z : A)</tt> or type <tt>(x y z : A) -&gt;
--   B</tt>.
TBind :: Range -> TypedBindingInfo -> List1 (NamedArg Binder) -> Type -> TypedBinding

-- | E.g. <tt>(let x = e)</tt> or <tt>(let open M)</tt>.
TLet :: Range -> List1 LetBinding -> TypedBinding
type Telescope1 = List1 TypedBinding
data Declaration

-- | Type signature (can be irrelevant, but not hidden).
--   
--   The fourth argument contains an optional assignment of polarities to
--   arguments.
Axiom :: KindOfName -> DefInfo -> ArgInfo -> Maybe [Occurrence] -> QName -> Type -> Declaration

-- | First argument is set of generalizable variables used in the type.
Generalize :: Set QName -> DefInfo -> ArgInfo -> QName -> Type -> Declaration

-- | record field
Field :: DefInfo -> QName -> Arg Type -> Declaration

-- | primitive function
Primitive :: DefInfo -> QName -> Arg Type -> Declaration

-- | a bunch of mutually recursive definitions
Mutual :: MutualInfo -> [Declaration] -> Declaration
Section :: Range -> Erased -> ModuleName -> GeneralizeTelescope -> [Declaration] -> Declaration

-- | The <tt>ImportDirective</tt> is for highlighting purposes.
Apply :: ModuleInfo -> Erased -> ModuleName -> ModuleApplication -> ScopeCopyInfo -> ImportDirective -> Declaration

-- | The <tt>ImportDirective</tt> is for highlighting purposes.
Import :: ModuleInfo -> ModuleName -> ImportDirective -> Declaration
Pragma :: Range -> Pragma -> Declaration
Open :: ModuleInfo -> ModuleName -> ImportDirective -> Declaration

-- | sequence of function clauses
FunDef :: DefInfo -> QName -> [Clause] -> Declaration

-- | lone data signature
DataSig :: DefInfo -> Erased -> QName -> GeneralizeTelescope -> Type -> Declaration
DataDef :: DefInfo -> QName -> UniverseCheck -> DataDefParams -> [Constructor] -> Declaration

-- | lone record signature
RecSig :: DefInfo -> Erased -> QName -> GeneralizeTelescope -> Type -> Declaration

-- | The <a>Type</a> gives the constructor type telescope, <tt>(x1 :
--   A1)..(xn : An) -&gt; Dummy</tt>, and the optional name is the
--   constructor's name. The optional <a>Range'</a> is for the
--   <tt>pattern</tt> attribute.
RecDef :: DefInfo -> QName -> UniverseCheck -> RecordDirectives -> DataDefParams -> Type -> [Declaration] -> Declaration

-- | Only for highlighting purposes
PatternSynDef :: QName -> [WithHiding BindName] -> Pattern' Void -> Declaration
UnquoteDecl :: MutualInfo -> [DefInfo] -> [QName] -> Expr -> Declaration
UnquoteDef :: [DefInfo] -> [QName] -> Expr -> Declaration
UnquoteData :: [DefInfo] -> QName -> UniverseCheck -> [DefInfo] -> [QName] -> Expr -> Declaration

-- | scope annotation
ScopedDecl :: ScopeInfo -> [Declaration] -> Declaration

-- | Only for highlighting the unfolded names
UnfoldingDecl :: Range -> [QName] -> Declaration
type RecordDirectives = RecordDirectives' QName
data ModuleApplication

-- | <tt>tel. M args</tt>: applies <tt>M</tt> to <tt>args</tt> and
--   abstracts <tt>tel</tt>.
SectionApp :: Telescope -> ModuleName -> [NamedArg Expr] -> ModuleApplication

-- | <pre>
--   M {{...}}
--   </pre>
RecordModuleInstance :: ModuleName -> ModuleApplication

-- | Only <a>Axiom</a>s.
type TypeSignature = Declaration
type ImportDirective = ImportDirective' QName ModuleName
type ImportedName = ImportedName' QName ModuleName
type Renaming = Renaming' QName ModuleName
type RewriteEqn = RewriteEqn' QName BindName Pattern Expr
type WithExpr = WithExpr' Expr
type LHSCore = LHSCore' Expr
data RHS
RHS :: Expr -> Maybe Expr -> RHS
[rhsExpr] :: RHS -> Expr

-- | We store the original concrete expression in case we have to reproduce
--   it during interactive case splitting. <a>Nothing</a> for internally
--   generated rhss.
[rhsConcrete] :: RHS -> Maybe Expr
AbsurdRHS :: RHS

-- | The <a>QName</a> is the name of the with function.
WithRHS :: QName -> [WithExpr] -> List1 Clause -> RHS
RewriteRHS :: [RewriteEqn] -> [ProblemEq] -> RHS -> WhereDeclarations -> RHS

-- | The <a>QName</a>s are the names of the generated with functions, one
--   for each <a>Expr</a>.
[rewriteExprs] :: RHS -> [RewriteEqn]

-- | The patterns stripped by with-desugaring. These are only present if
--   this rewrite follows a with.
[rewriteStrippedPats] :: RHS -> [ProblemEq]

-- | The RHS should not be another <tt>RewriteRHS</tt>.
[rewriteRHS] :: RHS -> RHS

-- | The where clauses are attached to the <tt>RewriteRHS</tt> by
[rewriteWhereDecls] :: RHS -> WhereDeclarations
type HoleContent = HoleContent' () BindName Pattern Expr
data ScopeCopyInfo
ScopeCopyInfo :: Ren ModuleName -> Ren QName -> ScopeCopyInfo
[renModules] :: ScopeCopyInfo -> Ren ModuleName
[renNames] :: ScopeCopyInfo -> Ren QName

-- | Renaming (generic).
type Ren a = Map a (List1 a)
type PatternSynDefn = ([WithHiding Name], Pattern' Void)
type PatternSynDefns = Map QName PatternSynDefn

-- | A user pattern together with an internal term that it should be equal
--   to after splitting is complete. Special cases: * User pattern is a
--   variable but internal term isn't: this will be turned into an as
--   pattern. * User pattern is a dot pattern: this pattern won't trigger
--   any splitting but will be checked for equality after all splitting is
--   complete and as patterns have been bound. * User pattern is an absurd
--   pattern: emptiness of the type will be checked after splitting is
--   complete. * User pattern is an annotated wildcard: type annotation
--   will be checked after splitting is complete.
data ProblemEq
ProblemEq :: Pattern -> Term -> Dom Type -> ProblemEq
[problemInPat] :: ProblemEq -> Pattern
[problemInst] :: ProblemEq -> Term
[problemType] :: ProblemEq -> Dom Type

-- | Extra information that is attached to a typed binding, that plays a
--   role during type checking but strictly speaking is not part of the
--   <tt>name : type</tt>" relation which a makes up a binding.
data TypedBindingInfo
TypedBindingInfo :: TacticAttribute -> Bool -> TypedBindingInfo

-- | Does this binding have a tactic annotation?
[tbTacticAttr] :: TypedBindingInfo -> TacticAttribute

-- | Does this binding correspond to a Partial binder, rather than to a Pi
--   binder? Must be present here to be reflected into abstract syntax
--   later (and to be printed to the user later).
[tbFinite] :: TypedBindingInfo -> Bool
type Field = TypeSignature
type NAPs e = [NamedArg (Pattern' e)]

-- | Parameterised over the type of dot patterns.
data Pattern' e
VarP :: BindName -> Pattern' e
ConP :: ConPatInfo -> AmbiguousQName -> NAPs e -> Pattern' e

-- | Destructor pattern <tt>d</tt>.
ProjP :: PatInfo -> ProjOrigin -> AmbiguousQName -> Pattern' e

-- | Defined pattern: function definition <tt>f ps</tt>. It is also abused
--   to convert destructor patterns into concrete syntax thus, we put
--   AmbiguousQName here as well.
DefP :: PatInfo -> AmbiguousQName -> NAPs e -> Pattern' e

-- | Underscore pattern entered by user. Or generated at type checking for
--   implicit arguments.
WildP :: PatInfo -> Pattern' e
AsP :: PatInfo -> BindName -> Pattern' e -> Pattern' e

-- | Dot pattern <tt>.e</tt>
DotP :: PatInfo -> e -> Pattern' e
AbsurdP :: PatInfo -> Pattern' e
LitP :: PatInfo -> Literal -> Pattern' e
PatternSynP :: PatInfo -> AmbiguousQName -> NAPs e -> Pattern' e
RecP :: ConPatInfo -> [FieldAssignment' (Pattern' e)] -> Pattern' e
EqualP :: PatInfo -> [(e, e)] -> Pattern' e

-- | <tt>| p</tt>, for with-patterns.
WithP :: PatInfo -> Pattern' e -> Pattern' e

-- | Pattern with type annotation
AnnP :: PatInfo -> e -> Pattern' e -> Pattern' e
type DefInfo = DefInfo' Expr

-- | A name in a binding position: we also compare the nameConcrete when
--   comparing the binders for equality.
--   
--   With <tt>--caching</tt> on we compare abstract syntax to determine if
--   we can reuse previous typechecking results: during that comparison two
--   names can have the same nameId but be semantically different, e.g. in
--   <tt>{_ : A} -&gt; ..</tt> vs. <tt>{r : A} -&gt; ..</tt>.
newtype BindName
BindName :: Name -> BindName
[unBind] :: BindName -> Name

-- | Bindings that are valid in a <tt>let</tt>.
data LetBinding

-- | <pre>
--   LetBind info rel name type defn
--   </pre>
LetBind :: LetInfo -> ArgInfo -> BindName -> Type -> Expr -> LetBinding

-- | Irrefutable pattern binding.
LetPatBind :: LetInfo -> Pattern -> Expr -> LetBinding

-- | <tt>LetApply mi newM (oldM args) renamings dir</tt>. The
--   <tt>ImportDirective</tt> is for highlighting purposes.
LetApply :: ModuleInfo -> Erased -> ModuleName -> ModuleApplication -> ScopeCopyInfo -> ImportDirective -> LetBinding

-- | only for highlighting and abstractToConcrete
LetOpen :: ModuleInfo -> ModuleName -> ImportDirective -> LetBinding

-- | Only used for highlighting. Refers to the first occurrence of
--   <tt>x</tt> in <tt>let x : A; x = e</tt>.
LetDeclaredVariable :: BindName -> LetBinding
type RecordAssigns = [RecordAssign]
type Assigns = [Assign]
type RecordAssign = Either Assign ModuleName
data GeneralizeTelescope
GeneralizeTel :: Map QName Name -> Telescope -> GeneralizeTelescope

-- | Maps generalize variables to the corresponding bound variable (to be
--   introduced by the generalisation).
[generalizeTelVars] :: GeneralizeTelescope -> Map QName Name
[generalizeTel] :: GeneralizeTelescope -> Telescope
data DataDefParams
DataDefParams :: Set Name -> [LamBinding] -> DataDefParams

-- | We don't yet know the position of generalized parameters from the data
--   sig, so we keep these in a set on the side.
[dataDefGeneralizedParams] :: DataDefParams -> Set Name
[dataDefParams] :: DataDefParams -> [LamBinding]

-- | We could throw away <tt>where</tt> clauses at this point and translate
--   them to <tt>let</tt>. It's not obvious how to remember that the
--   <tt>let</tt> was really a <tt>where</tt> clause though, so for the
--   time being we keep it here.
data Clause' lhs
Clause :: lhs -> [ProblemEq] -> RHS -> WhereDeclarations -> Bool -> Clause' lhs
[clauseLHS] :: Clause' lhs -> lhs

-- | Only in with-clauses where we inherit some already checked patterns
--   from the parent. These live in the context of the parent clause
--   left-hand side.
[clauseStrippedPats] :: Clause' lhs -> [ProblemEq]
[clauseRHS] :: Clause' lhs -> RHS
[clauseWhereDecls] :: Clause' lhs -> WhereDeclarations
[clauseCatchall] :: Clause' lhs -> Bool
data WhereDeclarations
WhereDecls :: Maybe ModuleName -> Bool -> Maybe Declaration -> WhereDeclarations
[whereModule] :: WhereDeclarations -> Maybe ModuleName

-- | is it an ordinary unnamed <tt>where</tt>?
[whereAnywhere] :: WhereDeclarations -> Bool

-- | The declaration is a <a>Section</a>.
[whereDecls] :: WhereDeclarations -> Maybe Declaration
type SpineClause = Clause' SpineLHS

-- | The lhs of a clause in spine view (inside-out). Projection patterns
--   are contained in <tt>spLhsPats</tt>, represented as <tt>ProjP d</tt>.
data SpineLHS
SpineLHS :: LHSInfo -> QName -> [NamedArg Pattern] -> SpineLHS

-- | Range.
[spLhsInfo] :: SpineLHS -> LHSInfo

-- | Name of function we are defining.
[spLhsDefName] :: SpineLHS -> QName

-- | Elimination by pattern, projections, with-patterns.
[spLhsPats] :: SpineLHS -> [NamedArg Pattern]
type WithExpr' e = Named BindName (Arg e)

-- | The lhs in projection-application and with-pattern view. Parameterised
--   over the type <tt>e</tt> of dot patterns.
data LHSCore' e

-- | The head applied to ordinary patterns.
LHSHead :: QName -> [NamedArg (Pattern' e)] -> LHSCore' e

-- | Head <tt>f</tt>.
[lhsDefName] :: LHSCore' e -> QName

-- | Applied to patterns <tt>ps</tt>.
[lhsPats] :: LHSCore' e -> [NamedArg (Pattern' e)]

-- | Projection.
LHSProj :: AmbiguousQName -> NamedArg (LHSCore' e) -> [NamedArg (Pattern' e)] -> LHSCore' e

-- | Record projection identifier.
[lhsDestructor] :: LHSCore' e -> AmbiguousQName

-- | Main argument of projection.
[lhsFocus] :: LHSCore' e -> NamedArg (LHSCore' e)

-- | Applied to patterns <tt>ps</tt>.
[lhsPats] :: LHSCore' e -> [NamedArg (Pattern' e)]

-- | With patterns.
LHSWith :: LHSCore' e -> [Arg (Pattern' e)] -> [NamedArg (Pattern' e)] -> LHSCore' e

-- | E.g. the <a>LHSHead</a>.
[lhsHead] :: LHSCore' e -> LHSCore' e

-- | Applied to with patterns <tt>| p1 | ... | pn</tt>. These patterns are
--   not prefixed with <tt>WithP</tt>!
[lhsWithPatterns] :: LHSCore' e -> [Arg (Pattern' e)]

-- | Applied to patterns <tt>ps</tt>.
[lhsPats] :: LHSCore' e -> [NamedArg (Pattern' e)]
type NAPs1 e = List1 (NamedArg (Pattern' e))
type Patterns = [NamedArg Pattern]

-- | Are we in an abstract block?
--   
--   In that case some definition is abstract.
class AnyAbstract a
anyAbstract :: AnyAbstract a => a -> Bool

-- | Turn a name into an expression.
class NameToExpr a
nameToExpr :: NameToExpr a => a -> Expr
class SubstExpr a
substExpr :: SubstExpr a => [(Name, Expr)] -> a -> a
substExpr :: (SubstExpr a, Functor t, SubstExpr b, t b ~ a) => [(Name, Expr)] -> a -> a

-- | Declaration spines. Used in debugging to make it easy to see where
--   constructors such as <a>ScopedDecl</a> and <a>Mutual</a> are placed.
data DeclarationSpine
AxiomS :: DeclarationSpine
GeneralizeS :: DeclarationSpine
FieldS :: DeclarationSpine
PrimitiveS :: DeclarationSpine
MutualS :: [DeclarationSpine] -> DeclarationSpine
SectionS :: [DeclarationSpine] -> DeclarationSpine
ApplyS :: DeclarationSpine
ImportS :: DeclarationSpine
PragmaS :: DeclarationSpine
OpenS :: DeclarationSpine
FunDefS :: [ClauseSpine] -> DeclarationSpine
DataSigS :: DeclarationSpine
DataDefS :: DeclarationSpine
RecSigS :: DeclarationSpine
RecDefS :: [DeclarationSpine] -> DeclarationSpine
PatternSynDefS :: DeclarationSpine
UnquoteDeclS :: DeclarationSpine
UnquoteDefS :: DeclarationSpine
UnquoteDataS :: DeclarationSpine
ScopedDeclS :: [DeclarationSpine] -> DeclarationSpine
UnfoldingDeclS :: DeclarationSpine

-- | Clause spines.
data ClauseSpine
ClauseS :: RHSSpine -> WhereDeclarationsSpine -> ClauseSpine

-- | Right-hand side spines.
data RHSSpine
RHSS :: RHSSpine
AbsurdRHSS :: RHSSpine
WithRHSS :: List1 ClauseSpine -> RHSSpine
RewriteRHSS :: RHSSpine -> WhereDeclarationsSpine -> RHSSpine

-- | Spines corresponding to <a>WhereDeclarations</a> values.
data WhereDeclarationsSpine
WhereDeclsS :: Maybe DeclarationSpine -> WhereDeclarationsSpine

-- | Pattern synonym for regular <a>Def</a>.
pattern Def :: QName -> Expr
app :: Expr -> [NamedArg Expr] -> Expr
mkBinder_ :: Name -> Binder
mkBinder :: a -> Binder' a
mkLet :: ExprInfo -> [LetBinding] -> Expr -> Expr
mkTLet :: Range -> [LetBinding] -> Maybe TypedBinding
mkBindName :: Name -> BindName

-- | Smart constructor for <a>Generalized</a>.
generalized :: Set QName -> Type -> Type
initCopyInfo :: ScopeCopyInfo
extractPattern :: Binder' a -> Maybe (Pattern, a)
mkDomainFree :: NamedArg Binder -> LamBinding
mkTBind :: Range -> List1 (NamedArg Binder) -> Type -> TypedBinding
mkPi :: ExprInfo -> Telescope -> Type -> Type
noDataDefParams :: DataDefParams
noWhereDecls :: WhereDeclarations

-- | The name defined by the given axiom.
--   
--   Precondition: The declaration has to be a (scoped) <a>Axiom</a>.
axiomName :: Declaration -> QName
lambdaLiftExpr :: [WithHiding Name] -> Expr -> Expr
insertImplicitPatSynArgs :: forall a. HasRange a => (Hiding -> Range -> a) -> Range -> [WithHiding Name] -> [NamedArg a] -> Maybe ([(Name, a)], [WithHiding Name])

-- | The declaration spine corresponding to a declaration.
declarationSpine :: Declaration -> DeclarationSpine

-- | The clause spine corresponding to a clause.
clauseSpine :: Clause -> ClauseSpine

-- | The right-hand side spine corresponding to a right-hand side.
rhsSpine :: RHS -> RHSSpine

-- | The spine corresponding to a <a>WhereDeclarations</a> value.
whereDeclarationsSpine :: WhereDeclarations -> WhereDeclarationsSpine
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.BindName
instance Agda.Syntax.Position.SetRange Agda.Syntax.Abstract.BindName
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.BindName
instance Agda.Syntax.Position.HasRange Agda.Syntax.Abstract.BindName
instance GHC.Show.Show Agda.Syntax.Abstract.BindName
instance GHC.Generics.Generic Agda.Syntax.Abstract.ScopeCopyInfo
instance GHC.Show.Show Agda.Syntax.Abstract.ScopeCopyInfo
instance GHC.Classes.Eq Agda.Syntax.Abstract.ScopeCopyInfo
instance GHC.Generics.Generic (Agda.Syntax.Abstract.Pattern' e)
instance GHC.Classes.Eq e => GHC.Classes.Eq (Agda.Syntax.Abstract.Pattern' e)
instance Data.Traversable.Traversable Agda.Syntax.Abstract.Pattern'
instance Data.Foldable.Foldable Agda.Syntax.Abstract.Pattern'
instance GHC.Base.Functor Agda.Syntax.Abstract.Pattern'
instance GHC.Show.Show e => GHC.Show.Show (Agda.Syntax.Abstract.Pattern' e)
instance GHC.Generics.Generic (Agda.Syntax.Abstract.LHSCore' e)
instance GHC.Classes.Eq e => GHC.Classes.Eq (Agda.Syntax.Abstract.LHSCore' e)
instance Data.Traversable.Traversable Agda.Syntax.Abstract.LHSCore'
instance Data.Foldable.Foldable Agda.Syntax.Abstract.LHSCore'
instance GHC.Base.Functor Agda.Syntax.Abstract.LHSCore'
instance GHC.Show.Show e => GHC.Show.Show (Agda.Syntax.Abstract.LHSCore' e)
instance GHC.Generics.Generic Agda.Syntax.Abstract.ProblemEq
instance GHC.Show.Show Agda.Syntax.Abstract.ProblemEq
instance GHC.Generics.Generic Agda.Syntax.Abstract.Pragma
instance GHC.Classes.Eq Agda.Syntax.Abstract.Pragma
instance GHC.Show.Show Agda.Syntax.Abstract.Pragma
instance GHC.Generics.Generic Agda.Syntax.Abstract.GeneralizeTelescope
instance GHC.Classes.Eq Agda.Syntax.Abstract.GeneralizeTelescope
instance GHC.Show.Show Agda.Syntax.Abstract.GeneralizeTelescope
instance GHC.Generics.Generic Agda.Syntax.Abstract.ModuleApplication
instance GHC.Classes.Eq Agda.Syntax.Abstract.ModuleApplication
instance GHC.Show.Show Agda.Syntax.Abstract.ModuleApplication
instance GHC.Generics.Generic Agda.Syntax.Abstract.LetBinding
instance GHC.Classes.Eq Agda.Syntax.Abstract.LetBinding
instance GHC.Show.Show Agda.Syntax.Abstract.LetBinding
instance GHC.Generics.Generic (Agda.Syntax.Abstract.Binder' a)
instance Data.Traversable.Traversable Agda.Syntax.Abstract.Binder'
instance Data.Foldable.Foldable Agda.Syntax.Abstract.Binder'
instance GHC.Base.Functor Agda.Syntax.Abstract.Binder'
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Abstract.Binder' a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Abstract.Binder' a)
instance GHC.Generics.Generic Agda.Syntax.Abstract.TypedBindingInfo
instance GHC.Classes.Eq Agda.Syntax.Abstract.TypedBindingInfo
instance GHC.Show.Show Agda.Syntax.Abstract.TypedBindingInfo
instance GHC.Generics.Generic Agda.Syntax.Abstract.TypedBinding
instance GHC.Classes.Eq Agda.Syntax.Abstract.TypedBinding
instance GHC.Show.Show Agda.Syntax.Abstract.TypedBinding
instance GHC.Generics.Generic Agda.Syntax.Abstract.LamBinding
instance GHC.Classes.Eq Agda.Syntax.Abstract.LamBinding
instance GHC.Show.Show Agda.Syntax.Abstract.LamBinding
instance GHC.Generics.Generic Agda.Syntax.Abstract.DataDefParams
instance GHC.Classes.Eq Agda.Syntax.Abstract.DataDefParams
instance GHC.Show.Show Agda.Syntax.Abstract.DataDefParams
instance GHC.Generics.Generic Agda.Syntax.Abstract.Declaration
instance GHC.Show.Show Agda.Syntax.Abstract.Declaration
instance GHC.Generics.Generic Agda.Syntax.Abstract.WhereDeclarations
instance GHC.Classes.Eq Agda.Syntax.Abstract.WhereDeclarations
instance GHC.Show.Show Agda.Syntax.Abstract.WhereDeclarations
instance GHC.Generics.Generic Agda.Syntax.Abstract.RHS
instance GHC.Show.Show Agda.Syntax.Abstract.RHS
instance GHC.Generics.Generic (Agda.Syntax.Abstract.Clause' lhs)
instance GHC.Classes.Eq lhs => GHC.Classes.Eq (Agda.Syntax.Abstract.Clause' lhs)
instance Data.Traversable.Traversable Agda.Syntax.Abstract.Clause'
instance Data.Foldable.Foldable Agda.Syntax.Abstract.Clause'
instance GHC.Base.Functor Agda.Syntax.Abstract.Clause'
instance GHC.Show.Show lhs => GHC.Show.Show (Agda.Syntax.Abstract.Clause' lhs)
instance GHC.Generics.Generic Agda.Syntax.Abstract.LHS
instance GHC.Show.Show Agda.Syntax.Abstract.LHS
instance GHC.Generics.Generic Agda.Syntax.Abstract.Expr
instance GHC.Show.Show Agda.Syntax.Abstract.Expr
instance GHC.Generics.Generic Agda.Syntax.Abstract.SpineLHS
instance GHC.Classes.Eq Agda.Syntax.Abstract.SpineLHS
instance GHC.Show.Show Agda.Syntax.Abstract.SpineLHS
instance GHC.Show.Show Agda.Syntax.Abstract.RHSSpine
instance GHC.Show.Show Agda.Syntax.Abstract.ClauseSpine
instance GHC.Show.Show Agda.Syntax.Abstract.DeclarationSpine
instance GHC.Show.Show Agda.Syntax.Abstract.WhereDeclarationsSpine
instance Agda.Syntax.Abstract.SubstExpr a => Agda.Syntax.Abstract.SubstExpr (GHC.Maybe.Maybe a)
instance Agda.Syntax.Abstract.SubstExpr a => Agda.Syntax.Abstract.SubstExpr [a]
instance Agda.Syntax.Abstract.SubstExpr a => Agda.Syntax.Abstract.SubstExpr (Agda.Utils.List1.List1 a)
instance Agda.Syntax.Abstract.SubstExpr a => Agda.Syntax.Abstract.SubstExpr (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Abstract.SubstExpr a => Agda.Syntax.Abstract.SubstExpr (Agda.Syntax.Common.Named name a)
instance Agda.Syntax.Abstract.SubstExpr a => Agda.Syntax.Abstract.SubstExpr (Agda.Syntax.Concrete.FieldAssignment' a)
instance (Agda.Syntax.Abstract.SubstExpr a, Agda.Syntax.Abstract.SubstExpr b) => Agda.Syntax.Abstract.SubstExpr (a, b)
instance (Agda.Syntax.Abstract.SubstExpr a, Agda.Syntax.Abstract.SubstExpr b) => Agda.Syntax.Abstract.SubstExpr (Data.Either.Either a b)
instance Agda.Syntax.Abstract.SubstExpr Agda.Syntax.Concrete.Name.Name
instance Agda.Syntax.Abstract.SubstExpr Agda.Syntax.Abstract.Name.ModuleName
instance Agda.Syntax.Abstract.SubstExpr Agda.Syntax.Abstract.Expr
instance Agda.Syntax.Abstract.NameToExpr Agda.Syntax.Scope.Base.AbstractName
instance Agda.Syntax.Abstract.NameToExpr Agda.Syntax.Scope.Base.ResolvedName
instance Agda.Syntax.Abstract.AnyAbstract a => Agda.Syntax.Abstract.AnyAbstract [a]
instance Agda.Syntax.Abstract.AnyAbstract Agda.Syntax.Abstract.Declaration
instance Agda.Syntax.Position.HasRange Agda.Syntax.Abstract.SpineLHS
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.SpineLHS
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.SpineLHS
instance Agda.Utils.Null.Null Agda.Syntax.Abstract.TypedBindingInfo
instance GHC.Classes.Eq Agda.Syntax.Abstract.ProblemEq
instance Agda.Utils.Null.Null Agda.Syntax.Abstract.WhereDeclarations
instance GHC.Classes.Eq Agda.Syntax.Abstract.RHS
instance GHC.Classes.Eq Agda.Syntax.Abstract.LHS
instance Agda.Syntax.Abstract.Name.IsProjP Agda.Syntax.Abstract.Expr
instance GHC.Classes.Eq Agda.Syntax.Abstract.Expr
instance GHC.Classes.Eq Agda.Syntax.Abstract.Declaration
instance Agda.Syntax.Common.Underscore Agda.Syntax.Abstract.Expr
instance Agda.Syntax.Common.LensHiding Agda.Syntax.Abstract.LamBinding
instance Agda.Syntax.Common.LensHiding Agda.Syntax.Abstract.TypedBinding
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange (Agda.Syntax.Abstract.Binder' a)
instance Agda.Syntax.Position.HasRange Agda.Syntax.Abstract.LamBinding
instance Agda.Syntax.Position.HasRange Agda.Syntax.Abstract.TypedBinding
instance Agda.Syntax.Position.HasRange Agda.Syntax.Abstract.Expr
instance Agda.Syntax.Position.HasRange Agda.Syntax.Abstract.Declaration
instance Agda.Syntax.Position.HasRange Agda.Syntax.Abstract.LHS
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange (Agda.Syntax.Abstract.Clause' a)
instance Agda.Syntax.Position.HasRange Agda.Syntax.Abstract.RHS
instance Agda.Syntax.Position.HasRange Agda.Syntax.Abstract.WhereDeclarations
instance Agda.Syntax.Position.HasRange Agda.Syntax.Abstract.LetBinding
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Syntax.Abstract.Binder' a)
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.LamBinding
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.GeneralizeTelescope
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.DataDefParams
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.TypedBindingInfo
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.TypedBinding
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.Expr
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.Declaration
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.ModuleApplication
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.LHS
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.Syntax.Abstract.Clause' a)
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.ProblemEq
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.RHS
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.WhereDeclarations
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.LetBinding
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.Expr
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.Declaration
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.ModuleApplication
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.Pragma
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.LetBinding
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.Syntax.Abstract.Binder' a)
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.LamBinding
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.TypedBinding
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.TypedBindingInfo
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.GeneralizeTelescope
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.DataDefParams
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.ProblemEq
instance Control.DeepSeq.NFData lhs => Control.DeepSeq.NFData (Agda.Syntax.Abstract.Clause' lhs)
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.WhereDeclarations
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.RHS
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.LHS
instance Agda.Syntax.Position.HasRange (Agda.Syntax.Abstract.LHSCore' e)
instance Agda.Syntax.Position.KillRange e => Agda.Syntax.Position.KillRange (Agda.Syntax.Abstract.LHSCore' e)
instance Control.DeepSeq.NFData e => Control.DeepSeq.NFData (Agda.Syntax.Abstract.LHSCore' e)
instance Agda.Syntax.Abstract.Name.IsProjP (Agda.Syntax.Abstract.Pattern' e)
instance Agda.Syntax.Position.HasRange (Agda.Syntax.Abstract.Pattern' e)
instance Agda.Syntax.Position.SetRange (Agda.Syntax.Abstract.Pattern' a)
instance Agda.Syntax.Position.KillRange e => Agda.Syntax.Position.KillRange (Agda.Syntax.Abstract.Pattern' e)
instance Control.DeepSeq.NFData e => Control.DeepSeq.NFData (Agda.Syntax.Abstract.Pattern' e)
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Abstract.ScopeCopyInfo
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.ScopeCopyInfo
instance Control.DeepSeq.NFData Agda.Syntax.Abstract.ScopeCopyInfo
instance GHC.Classes.Eq Agda.Syntax.Abstract.BindName
instance GHC.Classes.Ord Agda.Syntax.Abstract.BindName
instance Agda.Syntax.Position.KillRange Agda.Syntax.Abstract.Name.Suffix

module Agda.Syntax.Abstract.Views
data AppView' arg
Application :: Expr -> [NamedArg arg] -> AppView' arg
type AppView = AppView' Expr

-- | Gather applications to expose head and spine.
--   
--   Note: everything is an application, possibly of itself to 0 arguments
appView :: Expr -> AppView
appView' :: Expr -> AppView' (AppInfo, Expr)
maybeProjTurnPostfix :: Expr -> Maybe Expr
unAppView :: AppView -> Expr

-- | Collects plain lambdas.
data LamView
LamView :: [LamBinding] -> Expr -> LamView
lamView :: Expr -> LamView

-- | Collect <tt>A.Pi</tt>s.
data PiView
PiView :: [(ExprInfo, Telescope1)] -> Type -> PiView
piView :: Expr -> PiView
unPiView :: PiView -> Expr

-- | Gather top-level <a>AsP</a>atterns and <a>AnnP</a>atterns to expose
--   underlying pattern.
asView :: Pattern -> ([Name], [Expr], Pattern)

-- | Remove top <a>ScopedExpr</a> wrappers.
unScope :: Expr -> Expr

-- | Remove <a>ScopedExpr</a> wrappers everywhere.
--   
--   NB: Unless the implementation of <a>ExprLike</a> for clauses has been
--   finished, this does not work for clauses yet.
deepUnscope :: ExprLike a => a -> a
deepUnscopeDecls :: [Declaration] -> [Declaration]
deepUnscopeDecl :: Declaration -> [Declaration]
type RecurseExprFn m a = Applicative m => (Expr -> m Expr -> m Expr) -> a -> m a
type RecurseExprRecFn m = forall a. ExprLike a => a -> m a
type FoldExprFn m a = Monoid m => (Expr -> m) -> a -> m
type FoldExprRecFn m = forall a. ExprLike a => a -> m
type TraverseExprFn m a = (Applicative m, Monad m) => (Expr -> m Expr) -> a -> m a
type TraverseExprRecFn m = forall a. ExprLike a => a -> m a

-- | Apply an expression rewriting to every subexpression, inside-out. See
--   <a>Agda.Syntax.Internal.Generic</a>.
class ExprLike a

-- | The first expression is pre-traversal, the second one post-traversal.
recurseExpr :: ExprLike a => RecurseExprFn m a

-- | The first expression is pre-traversal, the second one post-traversal.
recurseExpr :: (ExprLike a, Traversable f, ExprLike a', a ~ f a', Applicative m) => (Expr -> m Expr -> m Expr) -> a -> m a
foldExpr :: ExprLike a => FoldExprFn m a
traverseExpr :: ExprLike a => TraverseExprFn m a
mapExpr :: ExprLike a => (Expr -> Expr) -> a -> a
type KName = WithKind QName

-- | Extracts "all" names which are declared in a <a>Declaration</a>.
--   
--   Includes: local modules and <tt>where</tt> clauses. Excludes: <tt>open
--   public</tt>, <tt>let</tt>, <tt>with</tt> function names, extended
--   lambdas.
class DeclaredNames a
declaredNames :: (DeclaredNames a, Collection KName m) => a -> m
declaredNames :: (DeclaredNames a, Foldable t, DeclaredNames b, t b ~ a) => Collection KName m => a -> m
instance GHC.Base.Functor Agda.Syntax.Abstract.Views.AppView'
instance Agda.Syntax.Abstract.Views.DeclaredNames a => Agda.Syntax.Abstract.Views.DeclaredNames [a]
instance Agda.Syntax.Abstract.Views.DeclaredNames a => Agda.Syntax.Abstract.Views.DeclaredNames (Agda.Utils.List1.List1 a)
instance Agda.Syntax.Abstract.Views.DeclaredNames a => Agda.Syntax.Abstract.Views.DeclaredNames (GHC.Maybe.Maybe a)
instance Agda.Syntax.Abstract.Views.DeclaredNames a => Agda.Syntax.Abstract.Views.DeclaredNames (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Abstract.Views.DeclaredNames a => Agda.Syntax.Abstract.Views.DeclaredNames (Agda.Syntax.Common.Named name a)
instance Agda.Syntax.Abstract.Views.DeclaredNames a => Agda.Syntax.Abstract.Views.DeclaredNames (Agda.Syntax.Concrete.FieldAssignment' a)
instance (Agda.Syntax.Abstract.Views.DeclaredNames a, Agda.Syntax.Abstract.Views.DeclaredNames b) => Agda.Syntax.Abstract.Views.DeclaredNames (Data.Either.Either a b)
instance (Agda.Syntax.Abstract.Views.DeclaredNames a, Agda.Syntax.Abstract.Views.DeclaredNames b) => Agda.Syntax.Abstract.Views.DeclaredNames (a, b)
instance Agda.Syntax.Abstract.Views.DeclaredNames Agda.Syntax.Abstract.Views.KName
instance Agda.Syntax.Abstract.Views.DeclaredNames Agda.Syntax.Abstract.RecordDirectives
instance Agda.Syntax.Abstract.Views.DeclaredNames Agda.Syntax.Abstract.Declaration
instance Agda.Syntax.Abstract.Views.DeclaredNames Agda.Syntax.Abstract.Pragma
instance Agda.Syntax.Abstract.Views.DeclaredNames Agda.Syntax.Abstract.Clause
instance Agda.Syntax.Abstract.Views.DeclaredNames Agda.Syntax.Abstract.WhereDeclarations
instance Agda.Syntax.Abstract.Views.DeclaredNames Agda.Syntax.Abstract.RHS
instance Agda.Syntax.Abstract.Views.ExprLike Agda.Syntax.Abstract.Expr
instance Agda.Syntax.Abstract.Views.ExprLike Agda.Syntax.Abstract.LetBinding
instance Agda.Syntax.Abstract.Views.ExprLike a => Agda.Syntax.Abstract.Views.ExprLike (Agda.Syntax.Abstract.Clause' a)
instance Agda.Syntax.Abstract.Views.ExprLike Agda.Syntax.Abstract.RHS
instance Agda.Syntax.Abstract.Views.ExprLike Agda.Syntax.Abstract.ModuleApplication
instance Agda.Syntax.Abstract.Views.ExprLike Agda.Syntax.Abstract.Pragma
instance Agda.Syntax.Abstract.Views.ExprLike Agda.Syntax.Abstract.Declaration
instance Agda.Syntax.Abstract.Views.ExprLike a => Agda.Syntax.Abstract.Views.ExprLike (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Abstract.Views.ExprLike a => Agda.Syntax.Abstract.Views.ExprLike (GHC.Maybe.Maybe a)
instance Agda.Syntax.Abstract.Views.ExprLike a => Agda.Syntax.Abstract.Views.ExprLike (Agda.Syntax.Common.Named x a)
instance Agda.Syntax.Abstract.Views.ExprLike a => Agda.Syntax.Abstract.Views.ExprLike (Agda.Syntax.Common.Ranged a)
instance Agda.Syntax.Abstract.Views.ExprLike a => Agda.Syntax.Abstract.Views.ExprLike [a]
instance Agda.Syntax.Abstract.Views.ExprLike a => Agda.Syntax.Abstract.Views.ExprLike (Agda.Utils.List1.List1 a)
instance Agda.Syntax.Abstract.Views.ExprLike a => Agda.Syntax.Abstract.Views.ExprLike (Agda.Syntax.Concrete.TacticAttribute' a)
instance (Agda.Syntax.Abstract.Views.ExprLike a, Agda.Syntax.Abstract.Views.ExprLike b) => Agda.Syntax.Abstract.Views.ExprLike (a, b)
instance Agda.Syntax.Abstract.Views.ExprLike GHC.Base.Void
instance Agda.Syntax.Abstract.Views.ExprLike a => Agda.Syntax.Abstract.Views.ExprLike (Agda.Syntax.Concrete.FieldAssignment' a)
instance (Agda.Syntax.Abstract.Views.ExprLike a, Agda.Syntax.Abstract.Views.ExprLike b) => Agda.Syntax.Abstract.Views.ExprLike (Data.Either.Either a b)
instance Agda.Syntax.Abstract.Views.ExprLike Agda.Syntax.Abstract.BindName
instance Agda.Syntax.Abstract.Views.ExprLike Agda.Syntax.Abstract.Name.ModuleName
instance Agda.Syntax.Abstract.Views.ExprLike Agda.Syntax.Abstract.Name.QName
instance Agda.Syntax.Abstract.Views.ExprLike Agda.Syntax.Abstract.LamBinding
instance Agda.Syntax.Abstract.Views.ExprLike Agda.Syntax.Abstract.GeneralizeTelescope
instance Agda.Syntax.Abstract.Views.ExprLike Agda.Syntax.Abstract.DataDefParams
instance Agda.Syntax.Abstract.Views.ExprLike Agda.Syntax.Abstract.TypedBindingInfo
instance Agda.Syntax.Abstract.Views.ExprLike Agda.Syntax.Abstract.TypedBinding
instance Agda.Syntax.Abstract.Views.ExprLike a => Agda.Syntax.Abstract.Views.ExprLike (Agda.Syntax.Abstract.Pattern' a)
instance (Agda.Syntax.Abstract.Views.ExprLike qn, Agda.Syntax.Abstract.Views.ExprLike nm, Agda.Syntax.Abstract.Views.ExprLike p, Agda.Syntax.Abstract.Views.ExprLike e) => Agda.Syntax.Abstract.Views.ExprLike (Agda.Syntax.Common.RewriteEqn' qn nm p e)
instance Agda.Syntax.Abstract.Views.ExprLike Agda.Syntax.Abstract.WhereDeclarations
instance Agda.Syntax.Abstract.Views.ExprLike Agda.Syntax.Abstract.LHS
instance Agda.Syntax.Abstract.Views.ExprLike a => Agda.Syntax.Abstract.Views.ExprLike (Agda.Syntax.Abstract.LHSCore' a)
instance Agda.Syntax.Abstract.Views.ExprLike a => Agda.Syntax.Abstract.Views.ExprLike (Agda.Syntax.Common.WithHiding a)
instance Agda.Syntax.Abstract.Views.ExprLike Agda.Syntax.Abstract.SpineLHS

module Agda.Syntax.Abstract.UsedNames

-- | All names used in an abstract expression. This is used when rendering
--   clauses to figure out which (implicit) pattern variables must be
--   preserved. For example, the for <tt>f : Nat → Nat</tt>, the clause
--   <tt>f {n} = 0</tt> can be printed as <tt>f = 0</tt> (dropping the
--   <tt>n</tt>), but <tt>f {n} = n</tt> must preserve the <tt>n</tt>.
allUsedNames :: Expr -> Set Name
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed Agda.Syntax.Abstract.UsedNames.BoundAndUsedNames
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed a => Agda.Syntax.Abstract.UsedNames.BoundAndUsed (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed a => Agda.Syntax.Abstract.UsedNames.BoundAndUsed (Agda.Syntax.Common.Named n a)
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed a => Agda.Syntax.Abstract.UsedNames.BoundAndUsed (Agda.Utils.List1.List1 a)
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed a => Agda.Syntax.Abstract.UsedNames.BoundAndUsed [a]
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed a => Agda.Syntax.Abstract.UsedNames.BoundAndUsed (GHC.Maybe.Maybe a)
instance (Agda.Syntax.Abstract.UsedNames.BoundAndUsed a, Agda.Syntax.Abstract.UsedNames.BoundAndUsed b) => Agda.Syntax.Abstract.UsedNames.BoundAndUsed (Data.Either.Either a b)
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed Agda.Syntax.Abstract.Name.ModuleName
instance (Agda.Syntax.Abstract.UsedNames.BoundAndUsed a, Agda.Syntax.Abstract.UsedNames.BoundAndUsed b) => Agda.Syntax.Abstract.UsedNames.BoundAndUsed (a, b)
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed Agda.Syntax.Abstract.Expr
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed lhs => Agda.Syntax.Abstract.UsedNames.BoundAndUsed (Agda.Syntax.Abstract.Clause' lhs)
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed Agda.Syntax.Abstract.RHS
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed Agda.Syntax.Abstract.LHS
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed e => Agda.Syntax.Abstract.UsedNames.BoundAndUsed (Agda.Syntax.Abstract.LHSCore' e)
instance (Agda.Syntax.Abstract.UsedNames.BoundAndUsed x, Agda.Syntax.Abstract.UsedNames.BoundAndUsed p, Agda.Syntax.Abstract.UsedNames.BoundAndUsed e) => Agda.Syntax.Abstract.UsedNames.BoundAndUsed (Agda.Syntax.Common.RewriteEqn' q x p e)
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed Agda.Syntax.Abstract.LetBinding
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed Agda.Syntax.Abstract.LamBinding
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed Agda.Syntax.Abstract.TypedBinding
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed name => Agda.Syntax.Abstract.UsedNames.BoundAndUsed (Agda.Syntax.Abstract.Binder' name)
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed Agda.Syntax.Abstract.BindName
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed e => Agda.Syntax.Abstract.UsedNames.BoundAndUsed (Agda.Syntax.Abstract.Pattern' e)
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed e => Agda.Syntax.Abstract.UsedNames.BoundAndUsed (Agda.Syntax.Concrete.FieldAssignment' e)
instance Agda.Syntax.Abstract.UsedNames.BoundAndUsed Agda.Syntax.Abstract.ModuleApplication
instance GHC.Base.Semigroup Agda.Syntax.Abstract.UsedNames.BoundAndUsedNames
instance GHC.Base.Monoid Agda.Syntax.Abstract.UsedNames.BoundAndUsedNames


-- | Pattern synonym utilities: folding pattern synonym definitions for
--   printing and merging pattern synonym definitions to handle overloaded
--   pattern synonyms.
module Agda.Syntax.Abstract.PatternSynonyms

-- | Match an expression against a pattern synonym.
matchPatternSyn :: PatternSynDefn -> Expr -> Maybe [WithHiding Expr]

-- | Match a pattern against a pattern synonym.
matchPatternSynP :: PatternSynDefn -> Pattern' e -> Maybe [WithHiding (Pattern' e)]

-- | Merge a list of pattern synonym definitions. Fails unless all
--   definitions have the same shape (i.e. equal up to renaming of
--   variables and constructor names).
mergePatternSynDefs :: List1 PatternSynDefn -> Maybe PatternSynDefn


-- | Auxiliary functions to handle patterns in the abstract syntax.
--   
--   Generic and specific traversals.
module Agda.Syntax.Abstract.Pattern
type NAP = NamedArg Pattern
class MapNamedArgPattern a
mapNamedArgPattern :: MapNamedArgPattern a => (NAP -> NAP) -> a -> a
mapNamedArgPattern :: (MapNamedArgPattern a, Functor f, MapNamedArgPattern a', a ~ f a') => (NAP -> NAP) -> a -> a

-- | Generic pattern traversal.
class APatternLike p where {
    type ADotT p;
}

-- | Fold pattern.
foldrAPattern :: (APatternLike p, Monoid m) => (Pattern' (ADotT p) -> m -> m) -> p -> m

-- | Fold pattern.
foldrAPattern :: (APatternLike p, Monoid m, Foldable f, APatternLike b, ADotT p ~ ADotT b, f b ~ p) => (Pattern' (ADotT p) -> m -> m) -> p -> m

-- | Traverse pattern.
traverseAPatternM :: (APatternLike p, Monad m) => (Pattern' (ADotT p) -> m (Pattern' (ADotT p))) -> (Pattern' (ADotT p) -> m (Pattern' (ADotT p))) -> p -> m p

-- | Traverse pattern.
traverseAPatternM :: (APatternLike p, Traversable f, APatternLike q, ADotT p ~ ADotT q, f q ~ p, Monad m) => (Pattern' (ADotT p) -> m (Pattern' (ADotT p))) -> (Pattern' (ADotT p) -> m (Pattern' (ADotT p))) -> p -> m p

-- | Compute from each subpattern a value and collect them all in a monoid.
foldAPattern :: (APatternLike p, Monoid m) => (Pattern' (ADotT p) -> m) -> p -> m

-- | Traverse pattern(s) with a modification before the recursive descent.
preTraverseAPatternM :: (APatternLike p, Monad m) => (Pattern' (ADotT p) -> m (Pattern' (ADotT p))) -> p -> m p

-- | Traverse pattern(s) with a modification after the recursive descent.
postTraverseAPatternM :: (APatternLike p, Monad m) => (Pattern' (ADotT p) -> m (Pattern' (ADotT p))) -> p -> m p

-- | Map pattern(s) with a modification after the recursive descent.
mapAPattern :: APatternLike p => (Pattern' (ADotT p) -> Pattern' (ADotT p)) -> p -> p

-- | Collect pattern variables in left-to-right textual order.
patternVars :: APatternLike p => p -> [Name]

-- | Check if a pattern contains a specific (sub)pattern.
containsAPattern :: APatternLike p => (Pattern' (ADotT p) -> Bool) -> p -> Bool

-- | Check if a pattern contains an absurd pattern. For instance, <tt>suc
--   ()</tt>, does so.
--   
--   Precondition: contains no pattern synonyms.
containsAbsurdPattern :: APatternLike p => p -> Bool

-- | Check if a pattern contains an @-pattern.
containsAsPattern :: APatternLike p => p -> Bool

-- | Check if any user-written pattern variables occur more than once, and
--   throw the given error if they do.
checkPatternLinearity :: (Monad m, APatternLike p) => p -> ([Name] -> m ()) -> m ()

-- | Pattern substitution.
--   
--   For the embedded expression, the given pattern substitution is turned
--   into an expression substitution.
substPattern :: [(Name, Pattern)] -> Pattern -> Pattern

-- | Pattern substitution, parametrized by substitution function for
--   embedded expressions.
substPattern' :: (e -> e) -> [(Name, Pattern' e)] -> Pattern' e -> Pattern' e

-- | Convert a pattern to an expression.
--   
--   Does not support all cases of patterns. Result has no <a>Range'</a>
--   info, except in identifiers.
--   
--   This function is only used in expanding pattern synonyms and in
--   <a>Agda.Syntax.Translation.InternalToAbstract</a>, so we can cut some
--   corners.
patternToExpr :: Pattern -> Expr

-- | Converting a pattern to an expression.
--   
--   The <a>Hiding</a> context is remembered to create instance metas when
--   translating absurd patterns in instance position.
class PatternToExpr p e
patToExpr :: PatternToExpr p e => p -> Reader Hiding e
patToExpr :: (PatternToExpr p e, Traversable t, PatternToExpr p' e', p ~ t p', e ~ t e') => p -> Reader Hiding e

-- | Split patterns into (patterns, trailing with-patterns).
splitOffTrailingWithPatterns :: Patterns -> (Patterns, Patterns)

-- | Get the tail of with-patterns of a pattern spine.
trailingWithPatterns :: Patterns -> Patterns

-- | The next patterns are ...
--   
--   (This view discards <a>PatInfo</a>.)
data LHSPatternView e

-- | Application patterns (non-empty list).
LHSAppP :: NAPs e -> LHSPatternView e

-- | A projection pattern. Is also stored unmodified here.
LHSProjP :: ProjOrigin -> AmbiguousQName -> NamedArg (Pattern' e) -> LHSPatternView e

-- | With patterns (non-empty list). These patterns are not prefixed with
--   <a>WithP</a>.
LHSWithP :: [Pattern' e] -> LHSPatternView e

-- | Construct the <a>LHSPatternView</a> of the given list (if not empty).
--   
--   Return the view and the remaining patterns.
lhsPatternView :: IsProjP e => NAPs e -> Maybe (LHSPatternView e, NAPs e)

-- | Convert a focused lhs to spine view and back.
class LHSToSpine a b
lhsToSpine :: LHSToSpine a b => a -> b
spineToLhs :: LHSToSpine a b => b -> a
lhsCoreToSpine :: LHSCore' e -> QNamed [NamedArg (Pattern' e)]
spineToLhsCore :: IsProjP e => QNamed [NamedArg (Pattern' e)] -> LHSCore' e

-- | Add applicative patterns (non-projection / non-with patterns) to the
--   right.
lhsCoreApp :: LHSCore' e -> [NamedArg (Pattern' e)] -> LHSCore' e

-- | Add with-patterns to the right.
lhsCoreWith :: LHSCore' e -> [Arg (Pattern' e)] -> LHSCore' e
lhsCoreAddChunk :: IsProjP e => LHSCore' e -> LHSPatternView e -> LHSCore' e

-- | Add projection, with, and applicative patterns to the right.
lhsCoreAddSpine :: IsProjP e => LHSCore' e -> [NamedArg (Pattern' e)] -> LHSCore' e

-- | Used for checking pattern linearity.
lhsCoreAllPatterns :: LHSCore' e -> [Pattern' e]

-- | Used in '<a>AbstractToConcrete'</a>. Returns a <a>DefP</a>.
lhsCoreToPattern :: LHSCore -> Pattern
mapLHSHead :: (QName -> [NamedArg Pattern] -> LHSCore) -> LHSCore -> LHSCore
instance GHC.Show.Show e => GHC.Show.Show (Agda.Syntax.Abstract.Pattern.LHSPatternView e)
instance Agda.Syntax.Abstract.Pattern.LHSToSpine Agda.Syntax.Abstract.Clause Agda.Syntax.Abstract.SpineClause
instance Agda.Syntax.Abstract.Pattern.LHSToSpine a b => Agda.Syntax.Abstract.Pattern.LHSToSpine [a] [b]
instance Agda.Syntax.Abstract.Pattern.LHSToSpine Agda.Syntax.Abstract.LHS Agda.Syntax.Abstract.SpineLHS
instance Agda.Syntax.Abstract.Pattern.PatternToExpr p e => Agda.Syntax.Abstract.Pattern.PatternToExpr [p] [e]
instance Agda.Syntax.Abstract.Pattern.PatternToExpr p e => Agda.Syntax.Abstract.Pattern.PatternToExpr (Agda.Syntax.Common.Named n p) (Agda.Syntax.Common.Named n e)
instance Agda.Syntax.Abstract.Pattern.PatternToExpr p e => Agda.Syntax.Abstract.Pattern.PatternToExpr (Agda.Syntax.Concrete.FieldAssignment' p) (Agda.Syntax.Concrete.FieldAssignment' e)
instance Agda.Syntax.Abstract.Pattern.PatternToExpr p e => Agda.Syntax.Abstract.Pattern.PatternToExpr (Agda.Syntax.Common.Arg p) (Agda.Syntax.Common.Arg e)
instance Agda.Syntax.Abstract.Pattern.PatternToExpr Agda.Syntax.Abstract.Pattern Agda.Syntax.Abstract.Expr
instance Agda.Syntax.Abstract.Pattern.APatternLike (Agda.Syntax.Abstract.Pattern' a)
instance Agda.Syntax.Abstract.Pattern.APatternLike a => Agda.Syntax.Abstract.Pattern.APatternLike (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Abstract.Pattern.APatternLike a => Agda.Syntax.Abstract.Pattern.APatternLike (Agda.Syntax.Common.Named n a)
instance Agda.Syntax.Abstract.Pattern.APatternLike a => Agda.Syntax.Abstract.Pattern.APatternLike [a]
instance Agda.Syntax.Abstract.Pattern.APatternLike a => Agda.Syntax.Abstract.Pattern.APatternLike (GHC.Maybe.Maybe a)
instance Agda.Syntax.Abstract.Pattern.APatternLike a => Agda.Syntax.Abstract.Pattern.APatternLike (Agda.Syntax.Concrete.FieldAssignment' a)
instance (Agda.Syntax.Abstract.Pattern.APatternLike a, Agda.Syntax.Abstract.Pattern.APatternLike b, Agda.Syntax.Abstract.Pattern.ADotT a GHC.Types.~ Agda.Syntax.Abstract.Pattern.ADotT b) => Agda.Syntax.Abstract.Pattern.APatternLike (a, b)
instance Agda.Syntax.Abstract.Pattern.MapNamedArgPattern Agda.Syntax.Abstract.Pattern.NAP
instance Agda.Syntax.Abstract.Pattern.MapNamedArgPattern a => Agda.Syntax.Abstract.Pattern.MapNamedArgPattern [a]
instance Agda.Syntax.Abstract.Pattern.MapNamedArgPattern a => Agda.Syntax.Abstract.Pattern.MapNamedArgPattern (Agda.Syntax.Concrete.FieldAssignment' a)
instance Agda.Syntax.Abstract.Pattern.MapNamedArgPattern a => Agda.Syntax.Abstract.Pattern.MapNamedArgPattern (GHC.Maybe.Maybe a)
instance (Agda.Syntax.Abstract.Pattern.MapNamedArgPattern a, Agda.Syntax.Abstract.Pattern.MapNamedArgPattern b) => Agda.Syntax.Abstract.Pattern.MapNamedArgPattern (a, b)
instance Agda.Syntax.Concrete.Pattern.IsWithP (Agda.Syntax.Abstract.Pattern' e)


-- | Types used for precise syntax highlighting.
module Agda.Interaction.Highlighting.Precise
data Aspect
Comment :: Aspect
Keyword :: Aspect
String :: Aspect
Number :: Aspect
Hole :: Aspect

-- | Symbols like forall, =, -&gt;, etc.
Symbol :: Aspect

-- | Things like Set and Prop.
PrimitiveType :: Aspect

-- | Is the name an operator part?
Name :: Maybe NameKind -> Bool -> Aspect

-- | Text occurring in pragmas that does not have a more specific aspect.
Pragma :: Aspect

-- | Non-code contents in literate Agda
Background :: Aspect

-- | Delimiters used to separate the Agda code blocks from the other
--   contents in literate Agda
Markup :: Aspect

-- | <tt>NameKind</tt>s are figured out during scope checking.
data NameKind

-- | Bound variable.
Bound :: NameKind

-- | Generalizable variable. (This includes generalizable variables that
--   have been generalized).
Generalizable :: NameKind

-- | Inductive or coinductive constructor.
Constructor :: Induction -> NameKind
Datatype :: NameKind

-- | Record field.
Field :: NameKind
Function :: NameKind

-- | Module name.
Module :: NameKind
Postulate :: NameKind

-- | Primitive.
Primitive :: NameKind

-- | Record type.
Record :: NameKind

-- | Named argument, like x in {x = v}
Argument :: NameKind

-- | Macro.
Macro :: NameKind

-- | Other aspects, generated by type checking. (These can overlap with
--   each other and with <a>Aspect</a>s.)
data OtherAspect
Error :: OtherAspect

-- | A warning that is considered fatal in the end.
ErrorWarning :: OtherAspect
DottedPattern :: OtherAspect
UnsolvedMeta :: OtherAspect

-- | Unsolved constraint not connected to meta-variable. This could for
--   instance be an emptyness constraint.
UnsolvedConstraint :: OtherAspect
TerminationProblem :: OtherAspect
PositivityProblem :: OtherAspect

-- | Used for highlighting unreachable clauses, unreachable RHS (because of
--   an absurd pattern), etc.
Deadcode :: OtherAspect

-- | Used for shadowed repeated variable names in telescopes.
ShadowingInTelescope :: OtherAspect
CoverageProblem :: OtherAspect

-- | When this constructor is used it is probably a good idea to include a
--   <a>note</a> explaining why the pattern is incomplete.
IncompletePattern :: OtherAspect

-- | Code which is being type-checked.
TypeChecks :: OtherAspect

-- | Function declaration without matching definition NB: We put
--   CatchallClause last so that it is overwritten by other, more
--   important, aspects in the emacs mode.
MissingDefinition :: OtherAspect
CatchallClause :: OtherAspect
ConfluenceProblem :: OtherAspect

-- | Syntactic aspects of the code. (These cannot overlap.)
--   
--   Meta information which can be associated with a character/character
--   range.
data Aspects
Aspects :: Maybe Aspect -> Set OtherAspect -> String -> Maybe DefinitionSite -> !TokenBased -> Aspects
[aspect] :: Aspects -> Maybe Aspect
[otherAspects] :: Aspects -> Set OtherAspect

-- | This note, if not null, can be displayed as a tool-tip or something
--   like that. It should contain useful information about the range (like
--   the module containing a certain identifier, or the fixity of an
--   operator).
[note] :: Aspects -> String

-- | The definition site of the annotated thing, if applicable and known.
[definitionSite] :: Aspects -> Maybe DefinitionSite

-- | Is this entry token-based?
[tokenBased] :: Aspects -> !TokenBased
data DefinitionSite
DefinitionSite :: TopLevelModuleName' Range -> Int -> Bool -> Maybe String -> DefinitionSite

-- | The defining module.
[defSiteModule] :: DefinitionSite -> TopLevelModuleName' Range

-- | The file position in that module. File positions are counted from 1.
[defSitePos] :: DefinitionSite -> Int

-- | Has this <tt>DefinitionSite</tt> been created at the defining site of
--   the name?
[defSiteHere] :: DefinitionSite -> Bool

-- | A pretty name for the HTML linking.
[defSiteAnchor] :: DefinitionSite -> Maybe String

-- | Is the highlighting "token-based", i.e. based only on information from
--   the lexer?
data TokenBased
TokenBased :: TokenBased
NotOnlyTokenBased :: TokenBased

-- | A limited kind of syntax highlighting information: a pair consisting
--   of <a>Ranges</a> and <a>Aspects</a>.
--   
--   Note the invariant which <a>RangePair</a>s should satisfy
--   (<a>rangePairInvariant</a>).
newtype RangePair
RangePair :: (Ranges, Aspects) -> RangePair
[rangePair] :: RangePair -> (Ranges, Aspects)

-- | Invariant for <a>RangePair</a>.
rangePairInvariant :: RangePair -> Bool

-- | Syntax highlighting information, represented by maps from positions to
--   <a>Aspects</a>.
--   
--   The first position in the file has number 1.
newtype PositionMap
PositionMap :: IntMap Aspects -> PositionMap
[positionMap] :: PositionMap -> IntMap Aspects

-- | Highlighting info with delayed merging.
--   
--   Merging large sets of highlighting info repeatedly might be costly.
--   The idea of this type is to accumulate small pieces of highlighting
--   information, and then to merge them all at the end.
--   
--   Note the invariant which values of this type should satisfy
--   (<a>delayedMergeInvariant</a>).
newtype DelayedMerge hl
DelayedMerge :: Endo [hl] -> DelayedMerge hl

-- | Invariant for <tt><a>DelayedMerge</a> hl</tt>, parametrised by the
--   invariant for <tt>hl</tt>.
--   
--   Additionally the endofunction should be extensionally equal to <tt>(fs
--   <a>++</a>)</tt> for some list <tt>fs</tt>.
delayedMergeInvariant :: (hl -> Bool) -> DelayedMerge hl -> Bool

-- | Highlighting information.
--   
--   Note the invariant which values of this type should satisfy
--   (<a>highlightingInfoInvariant</a>).
--   
--   This is a type synonym in order to make it easy to change to another
--   representation.
type HighlightingInfo = RangeMap Aspects

-- | The invariant for <a>HighlightingInfo</a>.
highlightingInfoInvariant :: HighlightingInfo -> Bool

-- | A type that is intended to be used when constructing highlighting
--   information.
--   
--   Note the invariant which values of this type should satisfy
--   (<a>highlightingInfoBuilderInvariant</a>).
--   
--   This is a type synonym in order to make it easy to change to another
--   representation.
--   
--   The type should be an instance of <tt><a>IsBasicRangeMap</a>
--   <a>Aspects</a></tt>, <a>Semigroup</a> and <a>Monoid</a>, and there
--   should be an instance of <tt><a>Convert</a>
--   <a>HighlightingInfoBuilder</a> <a>HighlightingInfo</a></tt>.
type HighlightingInfoBuilder = DelayedMerge RangePair

-- | The invariant for <a>HighlightingInfoBuilder</a>.
--   
--   Additionally the endofunction should be extensionally equal to <tt>(fs
--   <a>++</a>)</tt> for some list <tt>fs</tt>.
highlightingInfoBuilderInvariant :: HighlightingInfoBuilder -> Bool

-- | A variant of <a>mempty</a> with <a>tokenBased</a> set to
--   <a>NotOnlyTokenBased</a>.
parserBased :: Aspects

-- | Conversion from classification of the scope checker.
kindOfNameToNameKind :: KindOfName -> NameKind

-- | A class that is intended to make it easy to swap between different
--   range map implementations.
--   
--   Note that some <a>RangeMap</a> operations are not included in this
--   class.
class IsBasicRangeMap a m | m -> a

-- | The map <tt><a>singleton</a> rs x</tt> contains the ranges from
--   <tt>rs</tt>, and every position in those ranges is associated with
--   <tt>x</tt>.
singleton :: IsBasicRangeMap a m => Ranges -> a -> m

-- | Converts range maps to <a>IntMap</a>s from positions to values.
toMap :: IsBasicRangeMap a m => m -> IntMap a

-- | Converts the map to a list. The ranges are non-overlapping and
--   non-empty, and earlier ranges precede later ones in the list.
toList :: IsBasicRangeMap a m => m -> [(Range, a)]

-- | Returns the smallest range covering everything in the map (or
--   <a>Nothing</a>, if the range would be empty).
--   
--   Note that the default implementation of this operation might be
--   inefficient.
coveringRange :: IsBasicRangeMap a m => m -> Maybe Range

-- | Like <a>singleton</a>, but with several <a>Ranges</a> instead of only
--   one.
several :: (IsBasicRangeMap a hl, Monoid hl) => [Ranges] -> a -> hl

-- | Conversion between different types.
class Convert a b
convert :: Convert a b => a -> b

-- | Returns a <a>RangeMap</a> overlapping the given range, as well as the
--   rest of the map.
insideAndOutside :: Range -> RangeMap a -> (RangeMap a, RangeMap a)

-- | Restricts the <a>RangeMap</a> to the given range.
restrictTo :: Range -> RangeMap a -> RangeMap a
instance Control.DeepSeq.NFData Agda.Interaction.Highlighting.Precise.RangePair
instance GHC.Show.Show Agda.Interaction.Highlighting.Precise.RangePair
instance Control.DeepSeq.NFData Agda.Interaction.Highlighting.Precise.PositionMap
instance GHC.Show.Show Agda.Interaction.Highlighting.Precise.PositionMap
instance GHC.Base.Monoid (Agda.Interaction.Highlighting.Precise.DelayedMerge hl)
instance GHC.Base.Semigroup (Agda.Interaction.Highlighting.Precise.DelayedMerge hl)
instance Agda.Utils.RangeMap.IsBasicRangeMap Agda.Syntax.Common.Aspect.Aspects Agda.Interaction.Highlighting.Precise.RangePair
instance GHC.Base.Semigroup a => Agda.Utils.RangeMap.IsBasicRangeMap a (Agda.Interaction.Highlighting.Precise.DelayedMerge (Agda.Utils.RangeMap.RangeMap a))
instance Agda.Utils.RangeMap.IsBasicRangeMap Agda.Syntax.Common.Aspect.Aspects (Agda.Interaction.Highlighting.Precise.DelayedMerge Agda.Interaction.Highlighting.Precise.RangePair)
instance Agda.Utils.RangeMap.IsBasicRangeMap Agda.Syntax.Common.Aspect.Aspects (Agda.Interaction.Highlighting.Precise.DelayedMerge Agda.Interaction.Highlighting.Precise.PositionMap)
instance GHC.Base.Monoid hl => Agda.Interaction.Highlighting.Precise.Convert (Agda.Interaction.Highlighting.Precise.DelayedMerge hl) hl
instance Agda.Interaction.Highlighting.Precise.Convert (Agda.Utils.RangeMap.RangeMap Agda.Syntax.Common.Aspect.Aspects) (Agda.Utils.RangeMap.RangeMap Agda.Syntax.Common.Aspect.Aspects)
instance Agda.Interaction.Highlighting.Precise.Convert Agda.Interaction.Highlighting.Precise.PositionMap (Agda.Utils.RangeMap.RangeMap Agda.Syntax.Common.Aspect.Aspects)
instance Agda.Interaction.Highlighting.Precise.Convert (Agda.Interaction.Highlighting.Precise.DelayedMerge Agda.Interaction.Highlighting.Precise.PositionMap) (Agda.Utils.RangeMap.RangeMap Agda.Syntax.Common.Aspect.Aspects)
instance Agda.Interaction.Highlighting.Precise.Convert (Agda.Interaction.Highlighting.Precise.DelayedMerge Agda.Interaction.Highlighting.Precise.RangePair) Agda.Interaction.Highlighting.Precise.PositionMap
instance Agda.Interaction.Highlighting.Precise.Convert (Agda.Interaction.Highlighting.Precise.DelayedMerge Agda.Interaction.Highlighting.Precise.RangePair) (Agda.Utils.RangeMap.RangeMap Agda.Syntax.Common.Aspect.Aspects)
instance GHC.Show.Show hl => GHC.Show.Show (Agda.Interaction.Highlighting.Precise.DelayedMerge hl)
instance Agda.Utils.RangeMap.IsBasicRangeMap Agda.Syntax.Common.Aspect.Aspects Agda.Interaction.Highlighting.Precise.PositionMap
instance GHC.Base.Semigroup Agda.Interaction.Highlighting.Precise.PositionMap
instance GHC.Base.Monoid Agda.Interaction.Highlighting.Precise.PositionMap
instance GHC.Base.Semigroup Agda.Syntax.Common.Aspect.TokenBased
instance GHC.Base.Monoid Agda.Syntax.Common.Aspect.TokenBased
instance GHC.Base.Semigroup Agda.Syntax.Common.Aspect.DefinitionSite
instance GHC.Base.Semigroup Agda.Syntax.Common.Aspect.Aspects
instance GHC.Base.Monoid Agda.Syntax.Common.Aspect.Aspects
instance Control.DeepSeq.NFData Agda.Syntax.Common.Aspect.Aspect
instance Control.DeepSeq.NFData Agda.Syntax.Common.Aspect.OtherAspect
instance Control.DeepSeq.NFData Agda.Syntax.Common.Aspect.DefinitionSite
instance Control.DeepSeq.NFData Agda.Syntax.Common.Aspect.Aspects

module Agda.Utils.Update

-- | The <tt>ChangeT</tt> monad transformer.
data ChangeT m a

-- | Run a <a>ChangeT</a> computation, returning result plus change flag.
runChangeT :: Functor m => ChangeT m a -> m (a, Bool)

-- | Map a <a>ChangeT</a> computation (monad transformer action).
mapChangeT :: (m (a, Any) -> n (b, Any)) -> ChangeT m a -> ChangeT n b
type UpdaterT m a = a -> ChangeT m a

-- | Blindly run an updater.
runUpdaterT :: Functor m => UpdaterT m a -> a -> m (a, Bool)
type Change a = ChangeT Identity a

-- | The class of change monads.
class Monad m => MonadChange m
tellDirty :: MonadChange m => m ()
listenDirty :: MonadChange m => m a -> m (a, Bool)

-- | Run a <a>Change</a> computation, returning result plus change flag.
runChange :: Change a -> (a, Bool)
type Updater a = UpdaterT Identity a

-- | Replace result of updating with original input if nothing has changed.
sharing :: Monad m => UpdaterT m a -> UpdaterT m a

-- | Blindly run an updater.
runUpdater :: Updater a -> a -> (a, Bool)

-- | Mark a computation as dirty.
dirty :: Monad m => UpdaterT m a
ifDirty :: (Monad m, MonadChange m) => m a -> (a -> m b) -> (a -> m b) -> m b

-- | Like <a>Functor</a>, but preserving sharing.
class Traversable f => Updater1 f
updater1 :: Updater1 f => Updater a -> Updater (f a)
updates1 :: Updater1 f => Updater a -> Updater (f a)
update1 :: Updater1 f => Updater a -> EndoFun (f a)

-- | Like <tt>Bifunctor</tt>, but preserving sharing.
class Updater2 f
updater2 :: Updater2 f => Updater a -> Updater b -> Updater (f a b)
updates2 :: Updater2 f => Updater a -> Updater b -> Updater (f a b)
update2 :: Updater2 f => Updater a -> Updater b -> EndoFun (f a b)
instance Control.Monad.IO.Class.MonadIO m => Control.Monad.IO.Class.MonadIO (Agda.Utils.Update.ChangeT m)
instance Control.Monad.Fail.MonadFail m => Control.Monad.Fail.MonadFail (Agda.Utils.Update.ChangeT m)
instance Control.Monad.Trans.Class.MonadTrans Agda.Utils.Update.ChangeT
instance GHC.Base.Monad m => GHC.Base.Monad (Agda.Utils.Update.ChangeT m)
instance GHC.Base.Applicative m => GHC.Base.Applicative (Agda.Utils.Update.ChangeT m)
instance GHC.Base.Functor m => GHC.Base.Functor (Agda.Utils.Update.ChangeT m)
instance Agda.Utils.Update.Updater2 (,)
instance Agda.Utils.Update.Updater2 Data.Either.Either
instance Agda.Utils.Update.Updater1 GHC.Maybe.Maybe
instance Agda.Utils.Update.Updater1 []
instance Control.Monad.Trans.Control.MonadTransControl Agda.Utils.Update.ChangeT
instance GHC.Base.Monad m => Agda.Utils.Update.MonadChange (Agda.Utils.Update.ChangeT m)
instance Agda.Utils.Update.MonadChange Data.Functor.Identity.Identity
instance GHC.Base.Monad m => Agda.Utils.Update.MonadChange (Control.Monad.Trans.Identity.IdentityT m)


-- | Preprocess <a>Declaration</a>s, producing <a>NiceDeclaration</a>s.
--   
--   <ul>
--   <li>Attach fixity and syntax declarations to the definition they refer
--   to.</li>
--   <li>Distribute the following attributes to the individual definitions:
--   <tt>abstract</tt>, <tt>instance</tt>, <tt>postulate</tt>,
--   <tt>primitive</tt>, <tt>private</tt>, termination pragmas.</li>
--   <li>Gather the function clauses belonging to one function
--   definition.</li>
--   <li>Expand ellipsis <tt>...</tt> in function clauses following
--   <tt>with</tt>.</li>
--   <li>Infer mutual blocks. A block starts when a lone signature is
--   encountered, and ends when all lone signatures have seen their
--   definition.</li>
--   <li>Handle interleaved mutual blocks. In an `interleaved mutual' block
--   we:</li>
--   <li>leave the data and fun sigs in place</li>
--   <li>classify signatures in <tt>constructor</tt> block based on their
--   return type and group them all as a data def at the position in the
--   block where the first constructor for the data sig in question
--   occured</li>
--   <li>classify fun clauses based on the declared function used and group
--   them all as a fundef at the position in the block where the first such
--   fun clause appeared</li>
--   <li>Report basic well-formedness error, when one of the above
--   transformation fails. When possible, errors should be deferred to the
--   scope checking phase (ConcreteToAbstract), where we are in the TCM and
--   can produce more informative error messages.</li>
--   </ul>
module Agda.Syntax.Concrete.Definitions

-- | The nice declarations. No fixity declarations and function definitions
--   are contained in a single constructor instead of spread out between
--   type signatures and clauses. The <tt>private</tt>, <tt>postulate</tt>,
--   <tt>abstract</tt> and <tt>instance</tt> modifiers have been
--   distributed to the individual declarations.
--   
--   Observe the order of components:
--   
--   Range Fixity' Access IsAbstract IsInstance TerminationCheck
--   PositivityCheck
--   
--   further attributes
--   
--   (Q)Name
--   
--   content (Expr, Declaration ...)
data NiceDeclaration

-- | <a>IsAbstract</a> argument: We record whether a declaration was made
--   in an <tt>abstract</tt> block.
--   
--   <a>ArgInfo</a> argument: Axioms and functions can be declared
--   irrelevant. (<a>Hiding</a> should be <a>NotHidden</a>.)
Axiom :: Range -> Access -> IsAbstract -> IsInstance -> ArgInfo -> Name -> Expr -> NiceDeclaration
NiceField :: Range -> Access -> IsAbstract -> IsInstance -> TacticAttribute -> Name -> Arg Expr -> NiceDeclaration
PrimitiveFunction :: Range -> Access -> IsAbstract -> Name -> Arg Expr -> NiceDeclaration
NiceMutual :: KwRange -> TerminationCheck -> CoverageCheck -> PositivityCheck -> [NiceDeclaration] -> NiceDeclaration
NiceModule :: Range -> Access -> IsAbstract -> Erased -> QName -> Telescope -> [Declaration] -> NiceDeclaration
NiceModuleMacro :: Range -> Access -> Erased -> Name -> ModuleApplication -> OpenShortHand -> ImportDirective -> NiceDeclaration
NiceOpen :: Range -> QName -> ImportDirective -> NiceDeclaration
NiceImport :: Range -> QName -> Maybe AsName -> OpenShortHand -> ImportDirective -> NiceDeclaration
NicePragma :: Range -> Pragma -> NiceDeclaration
NiceRecSig :: Range -> Erased -> Access -> IsAbstract -> PositivityCheck -> UniverseCheck -> Name -> [LamBinding] -> Expr -> NiceDeclaration
NiceDataSig :: Range -> Erased -> Access -> IsAbstract -> PositivityCheck -> UniverseCheck -> Name -> [LamBinding] -> Expr -> NiceDeclaration

-- | An uncategorized function clause, could be a function clause without
--   type signature or a pattern lhs (e.g. for irrefutable let). The
--   <a>Declaration</a> is the actual <a>FunClause</a>.
NiceFunClause :: Range -> Access -> IsAbstract -> TerminationCheck -> CoverageCheck -> Catchall -> Declaration -> NiceDeclaration
FunSig :: Range -> Access -> IsAbstract -> IsInstance -> IsMacro -> ArgInfo -> TerminationCheck -> CoverageCheck -> Name -> Expr -> NiceDeclaration

-- | Block of function clauses (we have seen the type signature before).
--   The <a>Declaration</a>s are the original declarations that were
--   processed into this <a>FunDef</a> and are only used in
--   <tt>notSoNiceDeclaration</tt>. Andreas, 2017-01-01: Because of issue
--   #2372, we add <a>IsInstance</a> here. An alias should know that it is
--   an instance.
FunDef :: Range -> [Declaration] -> IsAbstract -> IsInstance -> TerminationCheck -> CoverageCheck -> Name -> [Clause] -> NiceDeclaration
NiceDataDef :: Range -> Origin -> IsAbstract -> PositivityCheck -> UniverseCheck -> Name -> [LamBinding] -> [NiceConstructor] -> NiceDeclaration
NiceLoneConstructor :: KwRange -> [NiceConstructor] -> NiceDeclaration

-- | <tt>(Maybe Range)</tt> gives range of the 'pattern' declaration.
NiceRecDef :: Range -> Origin -> IsAbstract -> PositivityCheck -> UniverseCheck -> Name -> [RecordDirective] -> [LamBinding] -> [Declaration] -> NiceDeclaration
NicePatternSyn :: Range -> Access -> Name -> [WithHiding Name] -> Pattern -> NiceDeclaration
NiceGeneralize :: Range -> Access -> ArgInfo -> TacticAttribute -> Name -> Expr -> NiceDeclaration
NiceUnquoteDecl :: Range -> Access -> IsAbstract -> IsInstance -> TerminationCheck -> CoverageCheck -> [Name] -> Expr -> NiceDeclaration
NiceUnquoteDef :: Range -> Access -> IsAbstract -> TerminationCheck -> CoverageCheck -> [Name] -> Expr -> NiceDeclaration
NiceUnquoteData :: Range -> Access -> IsAbstract -> PositivityCheck -> UniverseCheck -> Name -> [Name] -> Expr -> NiceDeclaration
NiceOpaque :: KwRange -> [QName] -> [NiceDeclaration] -> NiceDeclaration

-- | Only <a>Axiom</a>s.
type NiceConstructor = NiceTypeSignature

-- | Only <a>Axiom</a>s.
type NiceTypeSignature = NiceDeclaration

-- | One clause in a function definition. There is no guarantee that the
--   <a>LHS</a> actually declares the <a>Name</a>. We will have to check
--   that later.
data Clause
Clause :: Name -> Catchall -> LHS -> RHS -> WhereClause -> [Clause] -> Clause

-- | Exception with internal source code callstack
data DeclarationException
DeclarationException :: CallStack -> DeclarationException' -> DeclarationException
[deLocation] :: DeclarationException -> CallStack
[deException] :: DeclarationException -> DeclarationException'
data DeclarationWarning
DeclarationWarning :: CallStack -> DeclarationWarning' -> DeclarationWarning
[dwLocation] :: DeclarationWarning -> CallStack
[dwWarning] :: DeclarationWarning -> DeclarationWarning'

-- | Non-fatal errors encountered in the Nicifier.
data DeclarationWarning'

-- | Empty <tt>abstract</tt> block.
EmptyAbstract :: KwRange -> DeclarationWarning'

-- | Empty <tt>data _ where</tt> block.
EmptyConstructor :: KwRange -> DeclarationWarning'

-- | Empty <tt>field</tt> block.
EmptyField :: KwRange -> DeclarationWarning'

-- | Empty <tt>variable</tt> block.
EmptyGeneralize :: KwRange -> DeclarationWarning'

-- | Empty <tt>instance</tt> block
EmptyInstance :: KwRange -> DeclarationWarning'

-- | Empty <tt>macro</tt> block.
EmptyMacro :: KwRange -> DeclarationWarning'

-- | Empty <tt>mutual</tt> block.
EmptyMutual :: KwRange -> DeclarationWarning'

-- | Empty <tt>postulate</tt> block.
EmptyPostulate :: KwRange -> DeclarationWarning'

-- | Empty <tt>private</tt> block.
EmptyPrivate :: KwRange -> DeclarationWarning'

-- | Empty <tt>primitive</tt> block.
EmptyPrimitive :: KwRange -> DeclarationWarning'

-- | A <a>Hidden</a> identifier in a <tt>variable</tt> declaration. Hiding
--   has no effect there as generalized variables are always hidden (or
--   instance variables).
HiddenGeneralize :: Range -> DeclarationWarning'

-- | A {-# CATCHALL #-} pragma that does not precede a function clause.
InvalidCatchallPragma :: Range -> DeclarationWarning'

-- | Invalid definition in a constructor block
InvalidConstructor :: Range -> DeclarationWarning'

-- | Invalid constructor block (not inside an interleaved mutual block)
InvalidConstructorBlock :: Range -> DeclarationWarning'

-- | A {-# NON_COVERING #-} pragma that does not apply to any function.
InvalidCoverageCheckPragma :: Range -> DeclarationWarning'

-- | A {-# NO_POSITIVITY_CHECK #-} pragma that does not apply to any data
--   or record type.
InvalidNoPositivityCheckPragma :: Range -> DeclarationWarning'

-- | A {-# NO_UNIVERSE_CHECK #-} pragma that does not apply to a data or
--   record type.
InvalidNoUniverseCheckPragma :: Range -> DeclarationWarning'

-- | A {-# TERMINATING #-} and {-# NON_TERMINATING #-} pragma that does not
--   apply to any function.
InvalidTerminationCheckPragma :: Range -> DeclarationWarning'

-- | Definitions (e.g. constructors or functions) without a declaration.
MissingDeclarations :: [(Name, Range)] -> DeclarationWarning'

-- | Declarations (e.g. type signatures) without a definition.
MissingDefinitions :: [(Name, Range)] -> DeclarationWarning'
NotAllowedInMutual :: Range -> String -> DeclarationWarning'

-- | <tt>private</tt> has no effect on <tt>open public</tt>. (But the user
--   might think so.) <a>KwRange</a> is the range of the <tt>public</tt>
--   keyword.
OpenPublicPrivate :: KwRange -> DeclarationWarning'

-- | <tt>abstract</tt> has no effect on <tt>open public</tt>. (But the user
--   might think so.) <a>KwRange</a> is the range of the <tt>public</tt>
--   keyword.
OpenPublicAbstract :: KwRange -> DeclarationWarning'
PolarityPragmasButNotPostulates :: [Name] -> DeclarationWarning'

-- | Pragma <tt>{-# NO_TERMINATION_CHECK #-}</tt> has been replaced by
--   <tt>{-# TERMINATING #-}</tt> and <tt>{-# NON_TERMINATING #-}</tt>.
PragmaNoTerminationCheck :: Range -> DeclarationWarning'

-- | <tt>COMPILE</tt> pragmas are not allowed in safe mode.
PragmaCompiled :: Range -> DeclarationWarning'

-- | <tt>ETA</tt> pragma is unsafe.
SafeFlagEta :: Range -> DeclarationWarning'

-- | <tt>INJECTIVE</tt> pragma is unsafe.
SafeFlagInjective :: Range -> DeclarationWarning'

-- | <tt>NON_COVERING</tt> pragma is unsafe.
SafeFlagNoCoverageCheck :: Range -> DeclarationWarning'

-- | <tt>NO_POSITIVITY_CHECK</tt> pragma is unsafe.
SafeFlagNoPositivityCheck :: Range -> DeclarationWarning'

-- | <tt>NO_UNIVERSE_CHECK</tt> pragma is unsafe.
SafeFlagNoUniverseCheck :: Range -> DeclarationWarning'

-- | <tt>NON_TERMINATING</tt> pragma is unsafe.
SafeFlagNonTerminating :: Range -> DeclarationWarning'

-- | <tt>POLARITY</tt> pragma is unsafe.
SafeFlagPolarity :: Range -> DeclarationWarning'

-- | <tt>TERMINATING</tt> pragma is unsafe.
SafeFlagTerminating :: Range -> DeclarationWarning'
ShadowingInTelescope :: List1 (Name, List2 Range) -> DeclarationWarning'
UnknownFixityInMixfixDecl :: [Name] -> DeclarationWarning'
UnknownNamesInFixityDecl :: [Name] -> DeclarationWarning'
UnknownNamesInPolarityPragmas :: [Name] -> DeclarationWarning'

-- | <tt>abstract</tt> block with nothing that can (newly) be made
--   abstract.
UselessAbstract :: KwRange -> DeclarationWarning'

-- | <tt>instance</tt> block with nothing that can (newly) become an
--   instance.
UselessInstance :: KwRange -> DeclarationWarning'

-- | <tt>macro</tt> block with nothing that can (newly) be made macro.
UselessMacro :: KwRange -> DeclarationWarning'

-- | <tt>private</tt> block with nothing that can (newly) be made private.
UselessPrivate :: KwRange -> DeclarationWarning'

-- | Nicifier warnings turned into errors in <tt>--safe</tt> mode.
unsafeDeclarationWarning :: DeclarationWarning -> Bool

-- | Nicifier monad. Preserve the state when throwing an exception.
data Nice a

-- | Nicifier parameters.
data NiceEnv
NiceEnv :: Bool -> NiceEnv

-- | We are in a module declared <tt>--safe</tt> which is not a builtin
--   module.
[safeButNotBuiltin] :: NiceEnv -> Bool

-- | Run a Nicifier computation, return result and warnings (in
--   chronological order).
runNice :: NiceEnv -> Nice a -> (Either DeclarationException a, NiceWarnings)

-- | Main. Fixities (or more precisely syntax declarations) are needed when
--   grouping function clauses.
niceDeclarations :: Fixities -> [Declaration] -> Nice [NiceDeclaration]

-- | (Approximately) convert a <a>NiceDeclaration</a> back to a list of
--   <a>Declaration</a>s.
notSoNiceDeclarations :: NiceDeclaration -> [Declaration]

-- | Has the <a>NiceDeclaration</a> a field of type <a>IsAbstract</a>?
niceHasAbstract :: NiceDeclaration -> Maybe IsAbstract

-- | Termination measure is, for now, a variable name.
type Measure = Name
declarationWarningName :: DeclarationWarning -> WarningName
instance GHC.Show.Show Agda.Syntax.Concrete.Definitions.DeclKind
instance GHC.Classes.Eq Agda.Syntax.Concrete.Definitions.DeclKind
instance Agda.Syntax.Concrete.Definitions.MakePrivate a => Agda.Syntax.Concrete.Definitions.MakePrivate [a]
instance Agda.Syntax.Concrete.Definitions.MakePrivate Agda.Syntax.Common.Access
instance Agda.Syntax.Concrete.Definitions.MakePrivate Agda.Syntax.Concrete.Definitions.Types.NiceDeclaration
instance Agda.Syntax.Concrete.Definitions.MakePrivate Agda.Syntax.Concrete.Definitions.Types.Clause
instance Agda.Syntax.Concrete.Definitions.MakePrivate Agda.Syntax.Concrete.WhereClause
instance Agda.Syntax.Concrete.Definitions.MakeAbstract a => Agda.Syntax.Concrete.Definitions.MakeAbstract [a]
instance Agda.Syntax.Concrete.Definitions.MakeAbstract Agda.Syntax.Common.IsAbstract
instance Agda.Syntax.Concrete.Definitions.MakeAbstract Agda.Syntax.Concrete.Definitions.Types.NiceDeclaration
instance Agda.Syntax.Concrete.Definitions.MakeAbstract Agda.Syntax.Concrete.Definitions.Types.Clause
instance Agda.Syntax.Concrete.Definitions.MakeAbstract Agda.Syntax.Concrete.WhereClause
instance Agda.Syntax.Concrete.Definitions.MakeMacro a => Agda.Syntax.Concrete.Definitions.MakeMacro [a]
instance Agda.Syntax.Concrete.Definitions.MakeMacro Agda.Syntax.Concrete.Definitions.Types.NiceDeclaration


-- | Var field implementation of sets of (small) natural numbers.
module Agda.Utils.VarSet
type VarSet = IntSet

-- | &lt;math&gt;. The union of two sets.
union :: IntSet -> IntSet -> IntSet

-- | The union of a list of sets.
unions :: Foldable f => f IntSet -> IntSet

-- | &lt;math&gt;. Is the value a member of the set?
member :: Key -> IntSet -> Bool

-- | &lt;math&gt;. The empty set.
empty :: IntSet

-- | &lt;math&gt;. Delete a value in the set. Returns the original set when
--   the value was not present.
delete :: Key -> IntSet -> IntSet

-- | &lt;math&gt;. A set of one element.
singleton :: Key -> IntSet

-- | &lt;math&gt;. Create a set from a list of integers.
fromList :: [Key] -> IntSet

-- | &lt;math&gt;. Convert the set to a list of elements. Subject to list
--   fusion.
toList :: IntSet -> [Key]

-- | &lt;math&gt;. Convert the set to a descending list of elements.
--   Subject to list fusion.
toDescList :: IntSet -> [Key]

-- | &lt;math&gt;. Is this a subset? <tt>(s1 `isSubsetOf` s2)</tt> tells
--   whether <tt>s1</tt> is a subset of <tt>s2</tt>.
isSubsetOf :: IntSet -> IntSet -> Bool

-- | &lt;math&gt;. Is the set empty?
null :: IntSet -> Bool

-- | &lt;math&gt;. The intersection of two sets.
intersection :: IntSet -> IntSet -> IntSet

-- | &lt;math&gt;. Difference between two sets.
difference :: IntSet -> IntSet -> IntSet
subtract :: Int -> VarSet -> VarSet


-- | Construct a graph from constraints <tt> x + n <a>y becomes x
--   ---(-n)---</a> y x <a>n + y becomes x ---(+n)---</a> y </tt> the
--   default edge (= no edge) is labelled with infinity.
--   
--   Building the graph involves keeping track of the node names. We do
--   this in a finite map, assigning consecutive numbers to nodes.
module Agda.Utils.Warshall
type Matrix a = Array (Int, Int) a
warshall :: SemiRing a => Matrix a -> Matrix a
type AdjList node edge = Map node [(node, edge)]

-- | Warshall's algorithm on a graph represented as an adjacency list.
warshallG :: (SemiRing edge, Ord node) => AdjList node edge -> AdjList node edge

-- | Edge weight in the graph, forming a semi ring.
data Weight
Finite :: Int -> Weight
Infinite :: Weight
inc :: Weight -> Int -> Weight

-- | Nodes of the graph are either - flexible variables (with identifiers
--   drawn from <tt>Int</tt>), - rigid variables (also identified by
--   <tt>Int</tt>s), or - constants (like 0, infinity, or anything
--   between).
data Node
Rigid :: Rigid -> Node
Flex :: FlexId -> Node
data Rigid
RConst :: Weight -> Rigid
RVar :: RigidId -> Rigid
type NodeId = Int
type RigidId = Int
type FlexId = Int

-- | Which rigid variables a flex may be instatiated to.
type Scope = RigidId -> Bool
infinite :: Rigid -> Bool

-- | <tt>isBelow r w r'</tt> checks, if <tt>r</tt> and <tt>r'</tt> are
--   connected by <tt>w</tt> (meaning <tt>w</tt> not infinite), whether
--   <tt>r + w &lt;= r'</tt>. Precondition: not the same rigid variable.
isBelow :: Rigid -> Weight -> Rigid -> Bool

-- | A constraint is an edge in the graph.
data Constraint
NewFlex :: FlexId -> Scope -> Constraint

-- | For <tt>Arc v1 k v2</tt> at least one of <tt>v1</tt> or <tt>v2</tt> is
--   a <tt>MetaV</tt> (Flex), the other a <tt>MetaV</tt> or a <tt>Var</tt>
--   (Rigid). If <tt>k &lt;= 0</tt> this means <tt>suc^(-k) v1 &lt;=
--   v2</tt> otherwise <tt>v1 &lt;= suc^k v3</tt>.
Arc :: Node -> Int -> Node -> Constraint
type Constraints = [Constraint]
emptyConstraints :: Constraints
data Graph
Graph :: Map FlexId Scope -> Map Node NodeId -> Map NodeId Node -> NodeId -> (NodeId -> NodeId -> Weight) -> Graph

-- | Scope for each flexible var.
[flexScope] :: Graph -> Map FlexId Scope

-- | Node labels to node numbers.
[nodeMap] :: Graph -> Map Node NodeId

-- | Node numbers to node labels.
[intMap] :: Graph -> Map NodeId Node

-- | Number of nodes <tt>n</tt>.
[nextNode] :: Graph -> NodeId

-- | The edges (restrict to <tt>[0..n[</tt>).
[graph] :: Graph -> NodeId -> NodeId -> Weight

-- | The empty graph: no nodes, edges are all undefined (infinity weight).
initGraph :: Graph

-- | The Graph Monad, for constructing a graph iteratively.
type GM = State Graph

-- | Add a size meta node.
addFlex :: FlexId -> Scope -> GM ()

-- | Lookup identifier of a node. If not present, it is added first.
addNode :: Node -> GM Int

-- | <tt>addEdge n1 k n2</tt> improves the weight of egde
--   <tt>n1-&gt;n2</tt> to be at most <tt>k</tt>. Also adds nodes if not
--   yet present.
addEdge :: Node -> Int -> Node -> GM ()
addConstraint :: Constraint -> GM ()
buildGraph :: Constraints -> Graph
mkMatrix :: Int -> (Int -> Int -> Weight) -> Matrix Weight

-- | A matrix with row descriptions in <tt>b</tt> and column descriptions
--   in <tt>c</tt>.
data LegendMatrix a b c
LegendMatrix :: Matrix a -> (Int -> b) -> (Int -> c) -> LegendMatrix a b c
[matrix] :: LegendMatrix a b c -> Matrix a
[rowdescr] :: LegendMatrix a b c -> Int -> b
[coldescr] :: LegendMatrix a b c -> Int -> c

-- | A solution assigns to each flexible variable a size expression which
--   is either a constant or a <tt>v + n</tt> for a rigid variable
--   <tt>v</tt>.
type Solution = Map Int SizeExpr
emptySolution :: Solution
extendSolution :: Solution -> Int -> SizeExpr -> Solution
data SizeExpr

-- | e.g. x + 5
SizeVar :: RigidId -> Int -> SizeExpr

-- | a number or infinity
SizeConst :: Weight -> SizeExpr

-- | <tt>sizeRigid r n</tt> returns the size expression corresponding to
--   <tt>r + n</tt>
sizeRigid :: Rigid -> Int -> SizeExpr
solve :: Constraints -> Maybe Solution
instance GHC.Show.Show Agda.Utils.Warshall.Weight
instance GHC.Classes.Eq Agda.Utils.Warshall.Weight
instance GHC.Classes.Ord Agda.Utils.Warshall.Rigid
instance GHC.Classes.Eq Agda.Utils.Warshall.Rigid
instance GHC.Classes.Ord Agda.Utils.Warshall.Node
instance GHC.Classes.Eq Agda.Utils.Warshall.Node
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Warshall.SizeExpr
instance (Agda.Syntax.Common.Pretty.Pretty a, Agda.Syntax.Common.Pretty.Pretty b, Agda.Syntax.Common.Pretty.Pretty c) => Agda.Syntax.Common.Pretty.Pretty (Agda.Utils.Warshall.LegendMatrix a b c)
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Warshall.Constraint
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Warshall.Node
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Warshall.Weight
instance GHC.Classes.Ord Agda.Utils.Warshall.Weight
instance Agda.Utils.SemiRing.SemiRing Agda.Utils.Warshall.Weight


-- | Potentially uninitialised Booleans.
--   
--   The motivation for this small library is to distinguish between a
--   boolean option with a default value and an option which has been set
--   to what happens to be the default value. In one case the default can
--   be overriden (e.g. <tt>--cubical</tt> implies <tt>--without-K</tt>)
--   while in the other case the user has made a mistake which they need to
--   fix.
module Agda.Utils.WithDefault

-- | We don't want to have to remember for each flag whether its default
--   value is <tt>True</tt> or <tt>False</tt>. So we bake it into the
--   representation: the flag's type will mention its default value as a
--   phantom parameter.
data WithDefault' a (b :: Bool)
Default :: WithDefault' a (b :: Bool)
Value :: !a -> WithDefault' a (b :: Bool)
type WithDefault b = WithDefault' Bool b

-- | The main mode of operation of these flags, apart from setting them
--   explicitly, is to toggle them one way or the other if they hadn't been
--   set already.
setDefault :: Boolean a => a -> WithDefault' a b -> WithDefault' a b

-- | Only modify non-<a>Default</a> values.
mapValue :: Boolean a => (a -> a) -> WithDefault' a b -> WithDefault' a b

-- | Provided that the default value is a known boolean (in practice we
--   only use <tt>True</tt> or <tt>False</tt>), we can collapse a
--   potentially uninitialised value to a boolean.
collapseDefault :: (Boolean a, KnownBool b) => WithDefault' a b -> a

-- | Focus, overwriting <a>Default</a>.
lensCollapseDefault :: (Boolean a, KnownBool b) => Lens' (WithDefault' a b) a

-- | Update, but keep <a>Default</a> when new value is default value.
lensKeepDefault :: (Boolean a, Eq a, KnownBool b) => Lens' (WithDefault' a b) a
instance GHC.Show.Show a => GHC.Show.Show (Agda.Utils.WithDefault.WithDefault' a b)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Utils.WithDefault.WithDefault' a b)
instance Control.DeepSeq.NFData (Agda.Utils.WithDefault.WithDefault' a b)
instance Agda.Utils.Null.Null (Agda.Utils.WithDefault.WithDefault' a b)

module Agda.Utils.Zipper
class Zipper z where {
    type Carrier z;
    type Element z;
}
firstHole :: Zipper z => Carrier z -> Maybe (Element z, z)
plugHole :: Zipper z => Element z -> z -> Carrier z
nextHole :: Zipper z => Element z -> z -> Either (Carrier z) (Element z, z)
data ListZipper a
ListZip :: [a] -> [a] -> ListZipper a
data ComposeZipper f g
ComposeZip :: f -> g -> ComposeZipper f g
instance Data.Traversable.Traversable Agda.Utils.Zipper.ListZipper
instance Data.Foldable.Foldable Agda.Utils.Zipper.ListZipper
instance GHC.Base.Functor Agda.Utils.Zipper.ListZipper
instance GHC.Show.Show a => GHC.Show.Show (Agda.Utils.Zipper.ListZipper a)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.Utils.Zipper.ListZipper a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Utils.Zipper.ListZipper a)
instance (Agda.Utils.Zipper.Zipper f, Agda.Utils.Zipper.Zipper g, Agda.Utils.Zipper.Element f GHC.Types.~ Agda.Utils.Zipper.Carrier g) => Agda.Utils.Zipper.Zipper (Agda.Utils.Zipper.ComposeZipper f g)
instance Agda.Utils.Zipper.Zipper (Agda.Utils.Zipper.ListZipper a)

module Agda.Version

-- | The version of Agda.
version :: String

-- | This package name. This is mainly intended for use in the test suites
--   to filter ephemeral hash-fingerprinted package names like
--   <tt>Agda-2.6.2-5ceeWeguf1QFMaHLput4zw</tt>.
package :: String

-- | Returns a URL corresponding to the given section in the documentation
--   for the current version.
docsUrl :: String -> String
instance GHC.Generics.Generic Agda.Version.AnArbitrarySymbolInThisPackage

module Agda.VersionCommit
versionWithCommitInfo :: String

-- | Information about current git commit, generated at compile time
commitInfo :: Maybe String


-- | Library management.
--   
--   Sample use:
--   
--   <pre>
--   -- Get libraries as listed in <tt>.agda/libraries</tt> file.
--   libs &lt;- getInstalledLibraries Nothing
--   
--   -- Get the libraries (and immediate paths) relevant for <tt>projectRoot</tt>.
--   -- This involves locating and processing the <tt>.agda-lib</tt> file for the project.
--   (libNames, includePaths) &lt;-  getDefaultLibraries projectRoot True
--   
--   -- Get include paths of depended-on libraries.
--   resolvedPaths &lt;- libraryIncludePaths Nothing libs libNames
--   
--   let allPaths = includePaths ++ resolvedPaths
--   
--   </pre>
module Agda.Interaction.Library

-- | Get project root
findProjectRoot :: FilePath -> LibM (Maybe FilePath)

-- | Get the path to <tt>~/.agda</tt> (system-specific). Can be overwritten
--   by the <tt>AGDA_DIR</tt> environment variable.
--   
--   (This is not to be confused with the directory for the data files that
--   Agda needs (e.g. the primitive modules).)
getAgdaAppDir :: IO FilePath

-- | Get dependencies and include paths for given project root:
--   
--   Look for <tt>.agda-lib</tt> files according to
--   <tt>findAgdaLibFiles</tt>. If none are found, use default dependencies
--   (according to <tt>defaults</tt> file) and current directory (project
--   root).
getDefaultLibraries :: FilePath -> Bool -> LibM ([LibName], [FilePath])

-- | Parse the descriptions of the libraries Agda knows about.
--   
--   Returns none if there is no <tt>libraries</tt> file.
getInstalledLibraries :: Maybe FilePath -> LibM [AgdaLibFile]

-- | Return the trusted executables Agda knows about.
--   
--   Returns none if there is no <tt>executables</tt> file.
getTrustedExecutables :: LibM (Map ExeName FilePath)

-- | Get all include pathes for a list of libraries to use.
libraryIncludePaths :: Maybe FilePath -> [AgdaLibFile] -> [LibName] -> LibM [FilePath]

-- | Get the contents of <tt>.agda-lib</tt> files in the given project
--   root.
getAgdaLibFiles' :: FilePath -> LibErrorIO [AgdaLibFile]

-- | Returns the absolute default lib dir. This directory is used to store
--   the Primitive.agda file.
getPrimitiveLibDir :: IO FilePath

-- | A symbolic library name.
type LibName = String

-- | The options from an <tt>OPTIONS</tt> pragma (or a <tt>.agda-lib</tt>
--   file).
--   
--   In the future it might be nice to switch to a more structured
--   representation. Note that, currently, there is not a one-to-one
--   correspondence between list elements and options.
data OptionsPragma
OptionsPragma :: [String] -> Range -> OptionsPragma

-- | The options.
[pragmaStrings] :: OptionsPragma -> [String]

-- | The range of the options in the pragma (not including things like an
--   <tt>OPTIONS</tt> keyword).
[pragmaRange] :: OptionsPragma -> Range

-- | Content of a <tt>.agda-lib</tt> file.
data AgdaLibFile
AgdaLibFile :: LibName -> FilePath -> !Int -> [FilePath] -> [LibName] -> OptionsPragma -> AgdaLibFile

-- | The symbolic name of the library.
[_libName] :: AgdaLibFile -> LibName

-- | Path to this <tt>.agda-lib</tt> file (not content of the file).
[_libFile] :: AgdaLibFile -> FilePath

-- | How many directories above the Agda file is the <tt>.agda-lib</tt>
--   file located?
[_libAbove] :: AgdaLibFile -> !Int

-- | Roots where to look for the modules of the library.
[_libIncludes] :: AgdaLibFile -> [FilePath]

-- | Dependencies.
[_libDepends] :: AgdaLibFile -> [LibName]

-- | Default pragma options for all files in the library.
[_libPragmas] :: AgdaLibFile -> OptionsPragma

-- | A symbolic executable name.
type ExeName = Text

-- | Throws <a>LibErrors</a> exceptions, still collects <a>LibWarning</a>s.
type LibM = ExceptT LibErrors (WriterT [LibWarning] (StateT LibState IO))

-- | Raise collected <a>LibErrors</a> as exception.
mkLibM :: [AgdaLibFile] -> LibErrorIO a -> LibM a
data LibWarning
LibWarning :: Maybe LibPositionInfo -> LibWarning' -> LibWarning

-- | Information about which <tt>.agda-lib</tt> file we are reading and
--   from where in the <tt>libraries</tt> file it came from.
data LibPositionInfo
LibPositionInfo :: Maybe FilePath -> LineNumber -> FilePath -> LibPositionInfo

-- | Name of <tt>libraries</tt> file.
[libFilePos] :: LibPositionInfo -> Maybe FilePath

-- | Line number in <tt>libraries</tt> file.
[lineNumPos] :: LibPositionInfo -> LineNumber

-- | Library file.
[filePos] :: LibPositionInfo -> FilePath
libraryWarningName :: LibWarning -> WarningName

-- | A file can either belong to a project located at a given root
--   containing one or more .agda-lib files, or be part of the default
--   project.
data ProjectConfig
ProjectConfig :: FilePath -> [FilePath] -> !Int -> ProjectConfig
[configRoot] :: ProjectConfig -> FilePath
[configAgdaLibFiles] :: ProjectConfig -> [FilePath]

-- | How many directories above the Agda file is the <tt>.agda-lib</tt>
--   file located?
[configAbove] :: ProjectConfig -> !Int
DefaultProjectConfig :: ProjectConfig

-- | Library names are structured into the base name and a suffix of
--   version numbers, e.g. <tt>mylib-1.2.3</tt>. The version suffix is
--   optional.
data VersionView
VersionView :: LibName -> [Integer] -> VersionView

-- | Actual library name.
[vvBase] :: VersionView -> LibName

-- | Major version, minor version, subminor version, etc., all
--   non-negative. Note: a priori, there is no reason why the version
--   numbers should be <tt>Int</tt>s.
[vvNumbers] :: VersionView -> [Integer]

-- | Split a library name into basename and a list of version numbers.
--   
--   <pre>
--   versionView "foo-1.2.3"    == VersionView "foo" [1, 2, 3]
--   versionView "foo-01.002.3" == VersionView "foo" [1, 2, 3]
--   </pre>
--   
--   Note that because of leading zeros, <tt>versionView</tt> is not
--   injective. (<tt>unVersionView . versionView</tt> would produce a
--   normal form.)
versionView :: LibName -> VersionView

-- | Print a <tt>VersionView</tt>, inverse of <tt>versionView</tt> (modulo
--   leading zeros).
unVersionView :: VersionView -> LibName

-- | Generalized version of <a>findLib</a> for testing.
--   
--   <pre>
--   findLib' id "a"   [ "a-1", "a-02", "a-2", "b" ] == [ "a-02", "a-2" ]
--   </pre>
--   
--   <pre>
--   findLib' id "a"   [ "a", "a-1", "a-01", "a-2", "b" ] == [ "a" ]
--   findLib' id "a-1" [ "a", "a-1", "a-01", "a-2", "b" ] == [ "a-1", "a-01" ]
--   findLib' id "a-2" [ "a", "a-1", "a-01", "a-2", "b" ] == [ "a-2" ]
--   findLib' id "c"   [ "a", "a-1", "a-01", "a-2", "b" ] == []
--   </pre>
findLib' :: (a -> LibName) -> LibName -> [a] -> [a]
instance GHC.Show.Show Agda.Interaction.Library.VersionView
instance GHC.Classes.Eq Agda.Interaction.Library.VersionView

module Agda.Syntax.Common.Pretty.ANSI

-- | Render an annotated, pretty-printing <a>Doc</a>ument into a string
--   suitable for printing on VT100-compatible terminals.
renderAnsiIO :: Doc -> IO ()
putDoc :: (MonadIO m, HasOptions m) => Doc -> m ()

module Agda.Interaction.Options
data CommandLineOptions
Options :: String -> Maybe FilePath -> [FilePath] -> [AbsolutePath] -> [LibName] -> Maybe FilePath -> Bool -> Bool -> Integer -> Map ExeName FilePath -> Bool -> Bool -> Maybe PrintAgdaVersion -> Maybe Help -> Bool -> Bool -> Bool -> !Bool -> Maybe FilePath -> Bool -> Bool -> Bool -> Bool -> PragmaOptions -> Bool -> Bool -> DiagnosticsColours -> CommandLineOptions
[optProgramName] :: CommandLineOptions -> String
[optInputFile] :: CommandLineOptions -> Maybe FilePath
[optIncludePaths] :: CommandLineOptions -> [FilePath]

-- | The list should not contain duplicates.
[optAbsoluteIncludePaths] :: CommandLineOptions -> [AbsolutePath]
[optLibraries] :: CommandLineOptions -> [LibName]

-- | Use this (if <a>Just</a>) instead of <tt>~/.agda/libraries</tt>.
[optOverrideLibrariesFile] :: CommandLineOptions -> Maybe FilePath

-- | Use <tt>~/.agda/defaults</tt>.
[optDefaultLibs] :: CommandLineOptions -> Bool

-- | look for <tt>.agda-lib</tt> files.
[optUseLibs] :: CommandLineOptions -> Bool

-- | Configure notifications about imported modules.
[optTraceImports] :: CommandLineOptions -> Integer

-- | Map names of trusted executables to absolute paths.
[optTrustedExecutables] :: CommandLineOptions -> Map ExeName FilePath
[optPrintAgdaDataDir] :: CommandLineOptions -> Bool
[optPrintAgdaAppDir] :: CommandLineOptions -> Bool
[optPrintVersion] :: CommandLineOptions -> Maybe PrintAgdaVersion
[optPrintHelp] :: CommandLineOptions -> Maybe Help

-- | Agda REPL (<tt>-I</tt>).
[optInteractive] :: CommandLineOptions -> Bool
[optGHCiInteraction] :: CommandLineOptions -> Bool
[optJSONInteraction] :: CommandLineOptions -> Bool

-- | Exit if an interactive command fails.
[optExitOnError] :: CommandLineOptions -> !Bool

-- | In the absence of a path the project root is used.
[optCompileDir] :: CommandLineOptions -> Maybe FilePath
[optGenerateVimFile] :: CommandLineOptions -> Bool
[optIgnoreInterfaces] :: CommandLineOptions -> Bool
[optIgnoreAllInterfaces] :: CommandLineOptions -> Bool
[optLocalInterfaces] :: CommandLineOptions -> Bool
[optPragmaOptions] :: CommandLineOptions -> PragmaOptions

-- | Should the top-level module only be scope-checked, and not
--   type-checked?
[optOnlyScopeChecking] :: CommandLineOptions -> Bool

-- | Should code points that are not supported by the locale be
--   transliterated?
[optTransliterate] :: CommandLineOptions -> Bool

-- | Configure colour output.
[optDiagnosticsColour] :: CommandLineOptions -> DiagnosticsColours

-- | Options which can be set in a pragma.
data PragmaOptions
PragmaOptions :: WithDefault 'False -> WithDefault 'True -> WithDefault 'False -> WithDefault' UnicodeOrAscii 'True -> !Verbosity -> ProfileOptions -> WithDefault 'False -> WithDefault 'False -> WithDefault 'False -> WithDefault 'False -> WithDefault 'False -> WithDefault 'True -> WithDefault 'True -> CutOff -> WithDefault 'True -> WithDefault 'False -> WithDefault 'False -> WithDefault 'False -> WithDefault 'False -> WithDefault 'False -> WithDefault 'True -> WithDefault 'False -> WithDefault 'False -> WithDefault 'False -> WithDefault 'False -> WithDefault 'True -> WithDefault 'True -> WithDefault 'True -> WithDefault 'False -> WithDefault 'True -> WithDefault 'True -> WithDefault 'True -> WithDefault 'False -> WithDefault 'True -> WithDefault 'False -> WithDefault 'False -> Maybe Cubical -> WithDefault 'False -> WithDefault 'False -> WithDefault 'True -> WithDefault 'True -> WithDefault 'True -> WithDefault 'True -> Int -> WithDefault 'False -> WithDefault 'True -> Int -> WithDefault 'False -> WithDefault 'False -> !Maybe Int -> WarningMode -> WithDefault 'True -> WithDefault 'True -> WithDefault 'False -> WithDefault 'False -> WithDefault 'True -> WithDefault 'True -> WithDefault 'False -> Maybe ConfluenceCheck -> WithDefault 'False -> WithDefault 'False -> WithDefault 'True -> WithDefault 'True -> WithDefault 'False -> WithDefault 'True -> WithDefault 'False -> WithDefault 'False -> WithDefault 'False -> WithDefault 'True -> PragmaOptions
[_optShowImplicit] :: PragmaOptions -> WithDefault 'False

-- | Show generalized parameters in Pi types
[_optShowGeneralized] :: PragmaOptions -> WithDefault 'True
[_optShowIrrelevant] :: PragmaOptions -> WithDefault 'False
[_optUseUnicode] :: PragmaOptions -> WithDefault' UnicodeOrAscii 'True
[_optVerbose] :: PragmaOptions -> !Verbosity
[_optProfiling] :: PragmaOptions -> ProfileOptions
[_optProp] :: PragmaOptions -> WithDefault 'False
[_optLevelUniverse] :: PragmaOptions -> WithDefault 'False
[_optTwoLevel] :: PragmaOptions -> WithDefault 'False
[_optAllowUnsolved] :: PragmaOptions -> WithDefault 'False
[_optAllowIncompleteMatch] :: PragmaOptions -> WithDefault 'False
[_optPositivityCheck] :: PragmaOptions -> WithDefault 'True
[_optTerminationCheck] :: PragmaOptions -> WithDefault 'True

-- | Cut off structural order comparison at some depth in termination
--   checker?
[_optTerminationDepth] :: PragmaOptions -> CutOff
[_optUniverseCheck] :: PragmaOptions -> WithDefault 'True
[_optOmegaInOmega] :: PragmaOptions -> WithDefault 'False
[_optCumulativity] :: PragmaOptions -> WithDefault 'False
[_optSizedTypes] :: PragmaOptions -> WithDefault 'False
[_optGuardedness] :: PragmaOptions -> WithDefault 'False
[_optInjectiveTypeConstructors] :: PragmaOptions -> WithDefault 'False
[_optUniversePolymorphism] :: PragmaOptions -> WithDefault 'True
[_optIrrelevantProjections] :: PragmaOptions -> WithDefault 'False

-- | irrelevant levels, irrelevant data matching
[_optExperimentalIrrelevance] :: PragmaOptions -> WithDefault 'False
[_optWithoutK] :: PragmaOptions -> WithDefault 'False
[_optCubicalCompatible] :: PragmaOptions -> WithDefault 'False

-- | Allow definitions by copattern matching?
[_optCopatterns] :: PragmaOptions -> WithDefault 'True

-- | Is pattern matching allowed in the current file?
[_optPatternMatching] :: PragmaOptions -> WithDefault 'True
[_optExactSplit] :: PragmaOptions -> WithDefault 'True

-- | Should patterns of the form <tt>{x}</tt> or <tt>⦃ x ⦄</tt> be
--   interpreted as puns?
[_optHiddenArgumentPuns] :: PragmaOptions -> WithDefault 'False
[_optEta] :: PragmaOptions -> WithDefault 'True

-- | Perform the forcing analysis on data constructors?
[_optForcing] :: PragmaOptions -> WithDefault 'True

-- | Perform the projection-likeness analysis on functions?
[_optProjectionLike] :: PragmaOptions -> WithDefault 'True
[_optErasure] :: PragmaOptions -> WithDefault 'False

-- | Allow matching in erased positions for single-constructor, non-indexed
--   data/record types. (This kind of matching is always allowed for record
--   types with η-equality.)
[_optErasedMatches] :: PragmaOptions -> WithDefault 'True

-- | Mark parameters of record modules as erased?
[_optEraseRecordParameters] :: PragmaOptions -> WithDefault 'False

-- | Can rewrite rules be added and used?
[_optRewriting] :: PragmaOptions -> WithDefault 'False
[_optCubical] :: PragmaOptions -> Maybe Cubical
[_optGuarded] :: PragmaOptions -> WithDefault 'False

-- | Should we speculatively unify function applications as if they were
--   injective? Implies optRequireUniqueMetaSolutions.
[_optFirstOrder] :: PragmaOptions -> WithDefault 'False

-- | Forbid non-unique meta solutions allowed. For instance from
--   INJECTIVE_FOR_INFERENCE pragmas.
[_optRequireUniqueMetaSolutions] :: PragmaOptions -> WithDefault 'True

-- | Should system generated projections <tt>ProjSystem</tt> be printed
--   postfix (True) or prefix (False).
[_optPostfixProjections] :: PragmaOptions -> WithDefault 'True

-- | Should case splitting replace variables with dot patterns (False) or
--   keep them as variables (True).
[_optKeepPatternVariables] :: PragmaOptions -> WithDefault 'True

-- | Should case splitting and coverage checking try to discharge absurd
--   clauses? Default: <a>True</a>, but <a>False</a> might make coverage
--   checking considerably faster in some cases.
[_optInferAbsurdClauses] :: PragmaOptions -> WithDefault 'True
[_optInstanceSearchDepth] :: PragmaOptions -> Int
[_optBacktrackingInstances] :: PragmaOptions -> WithDefault 'False

-- | Should instance search consider instances with qualified names?
[_optQualifiedInstances] :: PragmaOptions -> WithDefault 'True
[_optInversionMaxDepth] :: PragmaOptions -> Int
[_optSafe] :: PragmaOptions -> WithDefault 'False
[_optDoubleCheck] :: PragmaOptions -> WithDefault 'False

-- | Should the conversion checker use the syntactic equality shortcut?
--   <a>Nothing</a> means that it should. <tt><a>Just</a> n</tt>, for a
--   non-negative number <tt>n</tt>, means that syntactic equality checking
--   gets <tt>n</tt> units of fuel. If the fuel becomes zero, then
--   syntactic equality checking is turned off. The fuel counter is
--   decreased in the failure continuation of
--   <a>checkSyntacticEquality</a>.
[_optSyntacticEquality] :: PragmaOptions -> !Maybe Int
[_optWarningMode] :: PragmaOptions -> WarningMode

-- | Treat the module given at the command line or via interaction as main
--   module in compilation?
[_optCompileMain] :: PragmaOptions -> WithDefault 'True
[_optCaching] :: PragmaOptions -> WithDefault 'True

-- | Count extended grapheme clusters rather than code points when
--   generating LaTeX.
[_optCountClusters] :: PragmaOptions -> WithDefault 'False

-- | Automatic compile-time inlining for simple definitions (unless marked
--   <tt>NOINLINE</tt>).
[_optAutoInline] :: PragmaOptions -> WithDefault 'False
[_optPrintPatternSynonyms] :: PragmaOptions -> WithDefault 'True

-- | Use the Agda abstract machine (<tt>fastReduce</tt>)?
[_optFastReduce] :: PragmaOptions -> WithDefault 'True

-- | Use call-by-name instead of call-by-need.
[_optCallByName] :: PragmaOptions -> WithDefault 'False

-- | Check confluence of rewrite rules?
[_optConfluenceCheck] :: PragmaOptions -> Maybe ConfluenceCheck

-- | Are the cohesion modalities available?
[_optCohesion] :: PragmaOptions -> WithDefault 'False

-- | Can we split on a <tt>(@flat x : A)</tt> argument?
[_optFlatSplit] :: PragmaOptions -> WithDefault 'False

-- | Should every top-level module start with an implicit statement
--   <tt>open import Agda.Primitive using (Set; Prop)</tt>?
[_optImportSorts] :: PragmaOptions -> WithDefault 'True

-- | Should we load the primitive modules at all? This is a stronger form
--   of <a>optImportSorts</a>.
[_optLoadPrimitives] :: PragmaOptions -> WithDefault 'True

-- | Allow running external <tt>executables</tt> from meta programs.
[_optAllowExec] :: PragmaOptions -> WithDefault 'False

-- | Save meta-variables to interface files.
[_optSaveMetas] :: PragmaOptions -> WithDefault 'True

-- | Show identity substitutions when pretty-printing terms (i.e. always
--   show all arguments of a metavariable).
[_optShowIdentitySubstitutions] :: PragmaOptions -> WithDefault 'False

-- | Do not discard clauses constructed by the coverage checker (needed for
--   some external backends).
[_optKeepCoveringClauses] :: PragmaOptions -> WithDefault 'False

-- | Allow large indices, and large forced arguments in constructors.
[_optLargeIndices] :: PragmaOptions -> WithDefault 'False

-- | Allow recursion on forced constructor arguments.
[_optForcedArgumentRecursion] :: PragmaOptions -> WithDefault 'True

-- | Warnings when parsing options.
data OptionWarning

-- | Name of option changed in a newer version of Agda.
OptionRenamed :: String -> String -> OptionWarning
[oldOptionName] :: OptionWarning -> String
[newOptionName] :: OptionWarning -> String

-- | A problem with setting or unsetting a warning.
WarningProblem :: WarningModeError -> OptionWarning
optionWarningName :: OptionWarning -> WarningName

-- | <tt>f :: Flag opts</tt> is an action on the option record that results
--   from parsing an option. <tt>f opts</tt> produces either an error
--   message or an updated options record
type Flag opts = opts -> OptM opts

-- | The options parse monad <a>OptM</a> collects warnings that are not
--   discarded when a fatal error occurrs
data OptM a
runOptM :: OptM opts -> (Either OptionError opts, OptionWarnings)

-- | Each <a>OptDescr</a> describes a single option.
--   
--   The arguments to <a>Option</a> are:
--   
--   <ul>
--   <li>list of short option characters</li>
--   <li>list of long option strings (without "--")</li>
--   <li>argument descriptor</li>
--   <li>explanation of option for user</li>
--   </ul>
data () => OptDescr a
Option :: [Char] -> [String] -> ArgDescr a -> String -> OptDescr a

-- | Describes whether an option takes an argument or not, and if so how
--   the argument is injected into a value of type <tt>a</tt>.
data () => ArgDescr a

-- | no argument expected
NoArg :: a -> ArgDescr a

-- | option requires argument
ReqArg :: (String -> a) -> String -> ArgDescr a

-- | optional argument
OptArg :: (Maybe String -> a) -> String -> ArgDescr a

-- | <a>Nothing</a> is used if no verbosity options have been given, thus
--   making it possible to handle the default case relatively quickly. Note
--   that <a>Nothing</a> corresponds to a trie with verbosity level 1 for
--   the empty path.
type Verbosity = Maybe (Trie VerboseKeyItem VerboseLevel)
type VerboseKey = String
type VerboseLevel = Int

-- | A <tt>WarningMode</tt> has two components: a set of warnings to be
--   displayed and a flag stating whether warnings should be turned into
--   fatal errors.
data WarningMode
WarningMode :: Set WarningName -> Bool -> WarningMode
[_warningSet] :: WarningMode -> Set WarningName
[_warn2Error] :: WarningMode -> Bool
data ConfluenceCheck
LocalConfluenceCheck :: ConfluenceCheck
GlobalConfluenceCheck :: ConfluenceCheck

-- | Options <tt>--version</tt> and <tt>--numeric-version</tt> (last wins).
data PrintAgdaVersion

-- | Print Agda version information and exit.
PrintAgdaVersion :: PrintAgdaVersion

-- | Print Agda version number and exit.
PrintAgdaNumericVersion :: PrintAgdaVersion

-- | We want to know whether we are allowed to insert unicode characters or
--   not.
data UnicodeOrAscii

-- | <a>true</a>: Unicode characters are allowed.
UnicodeOk :: UnicodeOrAscii

-- | 'false: Stick to ASCII.
AsciiOnly :: UnicodeOrAscii
data DiagnosticsColours
AlwaysColour :: DiagnosticsColours
NeverColour :: DiagnosticsColours
AutoColour :: DiagnosticsColours

-- | Checks that the given options are consistent. Also makes adjustments
--   (e.g. when one option implies another).
checkOpts :: MonadError OptionError m => CommandLineOptions -> m CommandLineOptions

-- | Parse options from an options pragma.
parsePragmaOptions :: OptionsPragma -> CommandLineOptions -> OptM PragmaOptions

-- | Parse options for a plugin.
parsePluginOptions :: [String] -> [OptDescr (Flag opts)] -> Flag opts
parseVerboseKey :: VerboseKey -> [VerboseKeyItem]

-- | Removes RTS options from a list of options.
stripRTS :: [String] -> [String]
defaultOptions :: CommandLineOptions
defaultInteractionOptions :: PragmaOptions

-- | The default termination depth.
defaultCutOff :: CutOff
defaultPragmaOptions :: PragmaOptions

-- | Used for printing usage info. Does not include the dead options.
standardOptions_ :: [OptDescr ()]

-- | Check for unsafe pragmas. Gives a list of used unsafe flags.
unsafePragmaOptions :: PragmaOptions -> [String]

-- | This function returns <a>True</a> if the file should be rechecked.
recheckBecausePragmaOptionsChanged :: PragmaOptions -> PragmaOptions -> Bool

-- | Infective or coinfective?
data InfectiveCoinfective
Infective :: InfectiveCoinfective
Coinfective :: InfectiveCoinfective

-- | Descriptions of infective and coinfective options.
data InfectiveCoinfectiveOption
ICOption :: (PragmaOptions -> Bool) -> String -> InfectiveCoinfective -> (PragmaOptions -> PragmaOptions -> Bool) -> (TopLevelModuleName -> Doc) -> InfectiveCoinfectiveOption

-- | Is the option active?
[icOptionActive] :: InfectiveCoinfectiveOption -> PragmaOptions -> Bool

-- | A description of the option (typically a flag that activates the
--   option).
[icOptionDescription] :: InfectiveCoinfectiveOption -> String

-- | Is the option (roughly speaking) infective or coinfective?
[icOptionKind] :: InfectiveCoinfectiveOption -> InfectiveCoinfective

-- | This function returns <a>True</a> exactly when, from the perspective
--   of the option in question, the options in the current module (the
--   first argument) are compatible with the options in a given imported
--   module (the second argument).
[icOptionOK] :: InfectiveCoinfectiveOption -> PragmaOptions -> PragmaOptions -> Bool

-- | A warning message that should be used if this option is not used
--   correctly. The given module name is the name of an imported module for
--   which <a>icOptionOK</a> failed.
[icOptionWarning] :: InfectiveCoinfectiveOption -> TopLevelModuleName -> Doc

-- | Infective and coinfective options.
--   
--   Note that <tt>--cubical</tt> and <tt>--erased-cubical</tt> are
--   "jointly infective": if one of them is used in one module, then one or
--   the other must be used in all modules that depend on this module.
infectiveCoinfectiveOptions :: [InfectiveCoinfectiveOption]
data ImpliedPragmaOption
[ImpliesPragmaOption] :: String -> Bool -> (PragmaOptions -> WithDefault a) -> String -> Bool -> (PragmaOptions -> WithDefault b) -> ImpliedPragmaOption
impliedPragmaOptions :: [ImpliedPragmaOption]
safeFlag :: Flag PragmaOptions

-- | Map a function over the long options. Also removes the short options.
--   Will be used to add the plugin name to the plugin options.
mapFlag :: (String -> String) -> OptDescr a -> OptDescr a

-- | The usage info message. The argument is the program name (probably
--   agda).
usage :: [OptDescr ()] -> String -> Help -> String
inputFlag :: FilePath -> Flag CommandLineOptions
standardOptions :: [OptDescr (Flag CommandLineOptions)]

-- | Command line options of previous versions of Agda. Should not be
--   listed in the usage info, put parsed by GetOpt for good error
--   messaging.
deadStandardOptions :: [OptDescr (Flag CommandLineOptions)]

-- | Simple interface for System.Console.GetOpt Could be moved to
--   Agda.Utils.Options (does not exist yet)
getOptSimple :: [String] -> [OptDescr (Flag opts)] -> (String -> Flag opts) -> Flag opts
lensOptShowImplicit :: Lens' PragmaOptions _
lensOptShowIrrelevant :: Lens' PragmaOptions _
lensOptUseUnicode :: Lens' PragmaOptions _
lensOptVerbose :: Lens' PragmaOptions _
lensOptProfiling :: Lens' PragmaOptions _
lensOptProp :: Lens' PragmaOptions _
lensOptLevelUniverse :: Lens' PragmaOptions _
lensOptTwoLevel :: Lens' PragmaOptions _
lensOptAllowUnsolved :: Lens' PragmaOptions _
lensOptAllowIncompleteMatch :: Lens' PragmaOptions _
lensOptPositivityCheck :: Lens' PragmaOptions _
lensOptTerminationCheck :: Lens' PragmaOptions _
lensOptTerminationDepth :: Lens' PragmaOptions _
lensOptUniverseCheck :: Lens' PragmaOptions _
lensOptNoUniverseCheck :: Lens' PragmaOptions _
lensOptOmegaInOmega :: Lens' PragmaOptions _
lensOptCumulativity :: Lens' PragmaOptions _
lensOptSizedTypes :: Lens' PragmaOptions _
lensOptGuardedness :: Lens' PragmaOptions _
lensOptInjectiveTypeConstructors :: Lens' PragmaOptions _
lensOptUniversePolymorphism :: Lens' PragmaOptions _
lensOptIrrelevantProjections :: Lens' PragmaOptions _
lensOptExperimentalIrrelevance :: Lens' PragmaOptions _
lensOptWithoutK :: Lens' PragmaOptions _
lensOptCubicalCompatible :: Lens' PragmaOptions _
lensOptCopatterns :: Lens' PragmaOptions _
lensOptPatternMatching :: Lens' PragmaOptions _
lensOptExactSplit :: Lens' PragmaOptions _
lensOptHiddenArgumentPuns :: Lens' PragmaOptions _
lensOptEta :: Lens' PragmaOptions _
lensOptForcing :: Lens' PragmaOptions _
lensOptProjectionLike :: Lens' PragmaOptions _
lensOptErasure :: Lens' PragmaOptions _
lensOptErasedMatches :: Lens' PragmaOptions _
lensOptEraseRecordParameters :: Lens' PragmaOptions _
lensOptRewriting :: Lens' PragmaOptions _
lensOptCubical :: Lens' PragmaOptions _
lensOptGuarded :: Lens' PragmaOptions _
lensOptFirstOrder :: Lens' PragmaOptions _
lensOptRequireUniqueMetaSolutions :: Lens' PragmaOptions _
lensOptPostfixProjections :: Lens' PragmaOptions _
lensOptKeepPatternVariables :: Lens' PragmaOptions _
lensOptInferAbsurdClauses :: Lens' PragmaOptions _
lensOptInstanceSearchDepth :: Lens' PragmaOptions _
lensOptBacktrackingInstances :: Lens' PragmaOptions _
lensOptQualifiedInstances :: Lens' PragmaOptions _
lensOptInversionMaxDepth :: Lens' PragmaOptions _
lensOptSafe :: Lens' PragmaOptions _
lensOptDoubleCheck :: Lens' PragmaOptions _
lensOptSyntacticEquality :: Lens' PragmaOptions _
lensOptWarningMode :: Lens' PragmaOptions _
lensOptCompileMain :: Lens' PragmaOptions _
lensOptCaching :: Lens' PragmaOptions _
lensOptCountClusters :: Lens' PragmaOptions _
lensOptAutoInline :: Lens' PragmaOptions _
lensOptPrintPatternSynonyms :: Lens' PragmaOptions _
lensOptFastReduce :: Lens' PragmaOptions _
lensOptCallByName :: Lens' PragmaOptions _
lensOptConfluenceCheck :: Lens' PragmaOptions _
lensOptCohesion :: Lens' PragmaOptions _
lensOptFlatSplit :: Lens' PragmaOptions _
lensOptImportSorts :: Lens' PragmaOptions _
lensOptLoadPrimitives :: Lens' PragmaOptions _
lensOptAllowExec :: Lens' PragmaOptions _
lensOptSaveMetas :: Lens' PragmaOptions _
lensOptShowIdentitySubstitutions :: Lens' PragmaOptions _
lensOptKeepCoveringClauses :: Lens' PragmaOptions _
optShowImplicit :: PragmaOptions -> Bool
optShowGeneralized :: PragmaOptions -> Bool
optShowIrrelevant :: PragmaOptions -> Bool
optProp :: PragmaOptions -> Bool
optLevelUniverse :: PragmaOptions -> Bool
optTwoLevel :: PragmaOptions -> Bool
optAllowUnsolved :: PragmaOptions -> Bool
optAllowIncompleteMatch :: PragmaOptions -> Bool
optPositivityCheck :: PragmaOptions -> Bool
optTerminationCheck :: PragmaOptions -> Bool
optUniverseCheck :: PragmaOptions -> Bool
optOmegaInOmega :: PragmaOptions -> Bool
optCumulativity :: PragmaOptions -> Bool
optSizedTypes :: PragmaOptions -> Bool
optGuardedness :: PragmaOptions -> Bool
optInjectiveTypeConstructors :: PragmaOptions -> Bool
optUniversePolymorphism :: PragmaOptions -> Bool
optIrrelevantProjections :: PragmaOptions -> Bool
optExperimentalIrrelevance :: PragmaOptions -> Bool
optWithoutK :: PragmaOptions -> Bool
optCubicalCompatible :: PragmaOptions -> Bool
optCopatterns :: PragmaOptions -> Bool
optPatternMatching :: PragmaOptions -> Bool
optHiddenArgumentPuns :: PragmaOptions -> Bool
optEta :: PragmaOptions -> Bool
optForcing :: PragmaOptions -> Bool
optProjectionLike :: PragmaOptions -> Bool

-- | <a>optErasure</a> is implied by <a>optEraseRecordParameters</a>.
--   <a>optErasure</a> is also implied by an explicitly given
--   `--erased-matches`.
optErasure :: PragmaOptions -> Bool
optErasedMatches :: PragmaOptions -> Bool
optEraseRecordParameters :: PragmaOptions -> Bool
optRewriting :: PragmaOptions -> Bool
optGuarded :: PragmaOptions -> Bool
optFirstOrder :: PragmaOptions -> Bool
optRequireUniqueMetaSolutions :: PragmaOptions -> Bool
optPostfixProjections :: PragmaOptions -> Bool
optKeepPatternVariables :: PragmaOptions -> Bool
optInferAbsurdClauses :: PragmaOptions -> Bool
optBacktrackingInstances :: PragmaOptions -> Bool
optQualifiedInstances :: PragmaOptions -> Bool
optSafe :: PragmaOptions -> Bool
optDoubleCheck :: PragmaOptions -> Bool
optCompileNoMain :: PragmaOptions -> Bool
optCaching :: PragmaOptions -> Bool
optCountClusters :: PragmaOptions -> Bool
optAutoInline :: PragmaOptions -> Bool
optPrintPatternSynonyms :: PragmaOptions -> Bool
optFastReduce :: PragmaOptions -> Bool
optCallByName :: PragmaOptions -> Bool

-- | <a>optCohesion</a> is implied by <a>optFlatSplit</a>.
optCohesion :: PragmaOptions -> Bool
optFlatSplit :: PragmaOptions -> Bool

-- | <a>optImportSorts</a> requires <a>optLoadPrimitives</a>.
optImportSorts :: PragmaOptions -> Bool
optLoadPrimitives :: PragmaOptions -> Bool
optAllowExec :: PragmaOptions -> Bool
optSaveMetas :: PragmaOptions -> Bool
optShowIdentitySubstitutions :: PragmaOptions -> Bool
optKeepCoveringClauses :: PragmaOptions -> Bool
optLargeIndices :: PragmaOptions -> Bool
optForcedArgumentRecursion :: PragmaOptions -> Bool
optConfluenceCheck :: PragmaOptions -> _
optCubical :: PragmaOptions -> _
optInstanceSearchDepth :: PragmaOptions -> _
optInversionMaxDepth :: PragmaOptions -> _
optProfiling :: PragmaOptions -> _
optSyntacticEquality :: PragmaOptions -> _
optTerminationDepth :: PragmaOptions -> _
optUseUnicode :: PragmaOptions -> UnicodeOrAscii
optVerbose :: PragmaOptions -> _
optWarningMode :: PragmaOptions -> _
class (Functor m, Applicative m, Monad m) => HasOptions m

-- | Returns the pragma options which are currently in effect.
pragmaOptions :: HasOptions m => m PragmaOptions

-- | Returns the command line options which are currently in effect.
commandLineOptions :: HasOptions m => m CommandLineOptions

-- | Returns the pragma options which are currently in effect.
pragmaOptions :: (HasOptions m, HasOptions n, MonadTrans t, m ~ t n) => m PragmaOptions

-- | Returns the command line options which are currently in effect.
commandLineOptions :: (HasOptions m, HasOptions n, MonadTrans t, m ~ t n) => m CommandLineOptions

module Agda.Interaction.Base

-- | Auxiliary state of an interactive computation.
data CommandState
CommandState :: [InteractionId] -> Maybe CurrentFile -> CommandLineOptions -> !OldInteractionScopes -> !CommandQueue -> CommandState

-- | The interaction points of the buffer, in the order in which they
--   appear in the buffer. The interaction points are recorded in
--   <tt>theTCState</tt>, but when new interaction points are added by give
--   or refine Agda does not ensure that the ranges of later interaction
--   points are updated.
[theInteractionPoints] :: CommandState -> [InteractionId]

-- | The file which the state applies to. Only stored if the module was
--   successfully type checked (potentially with warnings).
[theCurrentFile] :: CommandState -> Maybe CurrentFile

-- | Reset the options on each reload to these.
[optionsOnReload] :: CommandState -> CommandLineOptions

-- | We remember (the scope of) old interaction points to make it possible
--   to parse and compute highlighting information for the expression that
--   it got replaced by.
[oldInteractionScopes] :: CommandState -> !OldInteractionScopes

-- | The command queue.
--   
--   This queue should only be manipulated by
--   <tt>initialiseCommandQueue</tt> and <tt>maybeAbort</tt>.
[commandQueue] :: CommandState -> !CommandQueue
type OldInteractionScopes = Map InteractionId ScopeInfo

-- | Initial auxiliary interaction state
initCommandState :: CommandQueue -> CommandState

-- | Information about the current main module.
data CurrentFile
CurrentFile :: AbsolutePath -> TopLevelModuleName -> [String] -> ClockTime -> CurrentFile

-- | The file currently loaded into interaction.
[currentFilePath] :: CurrentFile -> AbsolutePath

-- | The top-level module name of the currently loaded file.
[currentFileModule] :: CurrentFile -> TopLevelModuleName

-- | The arguments to Agda used for loading the file.
[currentFileArgs] :: CurrentFile -> [String]

-- | The modification time stamp of the file when it was loaded.
[currentFileStamp] :: CurrentFile -> ClockTime

-- | A generalised command type.
data Command' a

-- | A command.
Command :: !a -> Command' a

-- | Stop processing commands.
Done :: Command' a

-- | An error message for a command that could not be parsed.
Error :: String -> Command' a

-- | IOTCM commands.
type Command = Command' IOTCM

-- | IOTCM commands.
--   
--   The commands are obtained by applying the functions to the current
--   top-level module name, if any. Note that the top-level module name is
--   not used by independent commands. For other commands the top-level
--   module name should be known.
type IOTCM = Maybe TopLevelModuleName -> IOTCM' Range

-- | Command queues.
data CommandQueue
CommandQueue :: !TChan (Integer, Command) -> !TVar (Maybe Integer) -> CommandQueue

-- | Commands that should be processed, in the order in which they should
--   be processed. Each command is associated with a number, and the
--   numbers are strictly increasing. Abort commands are not put on this
--   queue.
[commands] :: CommandQueue -> !TChan (Integer, Command)

-- | When this variable is set to <tt>Just n</tt> an attempt is made to
--   abort all commands with a command number that is at most <tt>n</tt>.
[abort] :: CommandQueue -> !TVar (Maybe Integer)

-- | An interactive computation.
type Interaction = Interaction' Range
data Interaction' range

-- | <tt>cmd_load m argv</tt> loads the module in file <tt>m</tt>, using
--   <tt>argv</tt> as the command-line options.
Cmd_load :: FilePath -> [String] -> Interaction' range

-- | <tt>cmd_compile b m argv</tt> compiles the module in file <tt>m</tt>
--   using the backend <tt>b</tt>, using <tt>argv</tt> as the command-line
--   options.
Cmd_compile :: CompilerBackend -> FilePath -> [String] -> Interaction' range
Cmd_constraints :: Interaction' range

-- | Show unsolved metas. If there are no unsolved metas but unsolved
--   constraints show those instead.
Cmd_metas :: Rewrite -> Interaction' range

-- | A command that fails if there are any unsolved meta-variables. By
--   default no output is generated if the command is successful.
Cmd_no_metas :: Interaction' range

-- | Shows all the top-level names in the given module, along with their
--   types. Uses the top-level scope.
Cmd_show_module_contents_toplevel :: Rewrite -> String -> Interaction' range

-- | Shows all the top-level names in scope which mention all the given
--   identifiers in their type.
Cmd_search_about_toplevel :: Rewrite -> String -> Interaction' range

-- | Solve (all goals / the goal at point) whose values are determined by
--   the constraints.
Cmd_solveAll :: Rewrite -> Interaction' range
Cmd_solveOne :: Rewrite -> InteractionId -> range -> String -> Interaction' range

-- | Solve (all goals / the goal at point) by using Mimer proof search.
Cmd_autoOne :: Rewrite -> InteractionId -> range -> String -> Interaction' range
Cmd_autoAll :: Rewrite -> Interaction' range

-- | Parse the given expression (as if it were defined at the top-level of
--   the current module) and infer its type.
Cmd_infer_toplevel :: Rewrite -> String -> Interaction' range

-- | Parse and type check the given expression (as if it were defined at
--   the top-level of the current module) and normalise it.
Cmd_compute_toplevel :: ComputeMode -> String -> Interaction' range

-- | <tt>cmd_load_highlighting_info source</tt> loads syntax highlighting
--   information for the module in <tt>source</tt>, and asks Emacs to apply
--   highlighting info from this file.
--   
--   If the module does not exist, or its module name is malformed or
--   cannot be determined, or the module has not already been visited, or
--   the cached info is out of date, then no highlighting information is
--   printed.
--   
--   This command is used to load syntax highlighting information when a
--   new file is opened, and it would probably be annoying if jumping to
--   the definition of an identifier reset the proof state, so this command
--   tries not to do that. One result of this is that the command uses the
--   current include directories, whatever they happen to be.
Cmd_load_highlighting_info :: FilePath -> Interaction' range

-- | Tells Agda to compute token-based highlighting information for the
--   file.
--   
--   This command works even if the file's module name does not match its
--   location in the file system, or if the file is not scope-correct.
--   Furthermore no file names are put in the generated output. Thus it is
--   fine to put source code into a temporary file before calling this
--   command. However, the file extension should be correct.
--   
--   If the second argument is <a>Remove</a>, then the (presumably
--   temporary) file is removed after it has been read.
Cmd_tokenHighlighting :: FilePath -> Remove -> Interaction' range

-- | Tells Agda to compute highlighting information for the expression just
--   spliced into an interaction point.
Cmd_highlight :: InteractionId -> range -> String -> Interaction' range

-- | Tells Agda whether or not to show implicit arguments.
ShowImplicitArgs :: Bool -> Interaction' range

-- | Toggle display of implicit arguments.
ToggleImplicitArgs :: Interaction' range

-- | Tells Agda whether or not to show irrelevant arguments.
ShowIrrelevantArgs :: Bool -> Interaction' range

-- | Toggle display of irrelevant arguments.
ToggleIrrelevantArgs :: Interaction' range

-- | Goal commands
--   
--   If the range is <a>noRange</a>, then the string comes from the
--   minibuffer rather than the goal.
Cmd_give :: UseForce -> InteractionId -> range -> String -> Interaction' range
Cmd_refine :: InteractionId -> range -> String -> Interaction' range
Cmd_intro :: Bool -> InteractionId -> range -> String -> Interaction' range
Cmd_refine_or_intro :: Bool -> InteractionId -> range -> String -> Interaction' range
Cmd_context :: Rewrite -> InteractionId -> range -> String -> Interaction' range
Cmd_helper_function :: Rewrite -> InteractionId -> range -> String -> Interaction' range
Cmd_infer :: Rewrite -> InteractionId -> range -> String -> Interaction' range
Cmd_goal_type :: Rewrite -> InteractionId -> range -> String -> Interaction' range

-- | Grabs the current goal's type and checks the expression in the hole
--   against it. Returns the elaborated term.
Cmd_elaborate_give :: Rewrite -> InteractionId -> range -> String -> Interaction' range

-- | Displays the current goal and context.
Cmd_goal_type_context :: Rewrite -> InteractionId -> range -> String -> Interaction' range

-- | Displays the current goal and context <i>and</i> infers the type of an
--   expression.
Cmd_goal_type_context_infer :: Rewrite -> InteractionId -> range -> String -> Interaction' range

-- | Grabs the current goal's type and checks the expression in the hole
--   against it.
Cmd_goal_type_context_check :: Rewrite -> InteractionId -> range -> String -> Interaction' range

-- | Shows all the top-level names in the given module, along with their
--   types. Uses the scope of the given goal.
Cmd_show_module_contents :: Rewrite -> InteractionId -> range -> String -> Interaction' range
Cmd_make_case :: InteractionId -> range -> String -> Interaction' range
Cmd_compute :: ComputeMode -> InteractionId -> range -> String -> Interaction' range
Cmd_why_in_scope :: InteractionId -> range -> String -> Interaction' range
Cmd_why_in_scope_toplevel :: String -> Interaction' range

-- | Displays version of the running Agda
Cmd_show_version :: Interaction' range

-- | Abort the current computation.
--   
--   Does nothing if no computation is in progress.
Cmd_abort :: Interaction' range

-- | Exit the program.
Cmd_exit :: Interaction' range
data IOTCM' range
IOTCM :: FilePath -> HighlightingLevel -> HighlightingMethod -> Interaction' range -> IOTCM' range

-- | Used to indicate whether something should be removed or not.
data Remove
Remove :: Remove
Keep :: Remove

-- | An <a>IOTCM</a> parser.
--   
--   If the parse fails, then an error message is returned.
parseIOTCM :: String -> Either String IOTCM

-- | The <a>Parse</a> monad. <a>StateT</a> state holds the remaining input.
type Parse a = ExceptT String (StateT String Identity) a

-- | Converter from the type of <a>reads</a> to <a>Parse</a> The first
--   paramter is part of the error message in case the parse fails.
readsToParse :: String -> (String -> Maybe (a, String)) -> Parse a
parseToReadsPrec :: Parse a -> Int -> String -> [(a, String)]

-- | Demand an exact string.
exact :: String -> Parse ()
readParse :: Read a => Parse a
parens' :: Parse a -> Parse a

-- | Available backends.
data CompilerBackend
LaTeX :: CompilerBackend
QuickLaTeX :: CompilerBackend
OtherBackend :: String -> CompilerBackend

-- | Ordered ascendingly by degree of normalization.
data Rewrite
AsIs :: Rewrite
Instantiated :: Rewrite
HeadNormal :: Rewrite
Simplified :: Rewrite
Normalised :: Rewrite
data ComputeMode
DefaultCompute :: ComputeMode
HeadCompute :: ComputeMode
IgnoreAbstract :: ComputeMode
UseShowInstance :: ComputeMode
data UseForce

-- | Ignore additional checks, like termination/positivity...
WithForce :: UseForce

-- | Don't ignore any checks.
WithoutForce :: UseForce
data OutputForm_boot tcErr a b
OutputForm :: Range -> [ProblemId] -> Blocker -> OutputConstraint_boot tcErr a b -> OutputForm_boot tcErr a b
data OutputConstraint_boot tcErr a b
OfType :: b -> a -> OutputConstraint_boot tcErr a b
CmpInType :: Comparison -> a -> b -> b -> OutputConstraint_boot tcErr a b
CmpElim :: [Polarity] -> a -> [b] -> [b] -> OutputConstraint_boot tcErr a b
JustType :: b -> OutputConstraint_boot tcErr a b
CmpTypes :: Comparison -> b -> b -> OutputConstraint_boot tcErr a b
CmpLevels :: Comparison -> b -> b -> OutputConstraint_boot tcErr a b
CmpTeles :: Comparison -> b -> b -> OutputConstraint_boot tcErr a b
JustSort :: b -> OutputConstraint_boot tcErr a b
CmpSorts :: Comparison -> b -> b -> OutputConstraint_boot tcErr a b
Assign :: b -> a -> OutputConstraint_boot tcErr a b
TypedAssign :: b -> a -> a -> OutputConstraint_boot tcErr a b
PostponedCheckArgs :: b -> [a] -> a -> a -> OutputConstraint_boot tcErr a b
IsEmptyType :: a -> OutputConstraint_boot tcErr a b
SizeLtSat :: a -> OutputConstraint_boot tcErr a b
FindInstanceOF :: b -> a -> [(a, a, a)] -> OutputConstraint_boot tcErr a b
ResolveInstanceOF :: QName -> OutputConstraint_boot tcErr a b
PTSInstance :: b -> b -> OutputConstraint_boot tcErr a b
PostponedCheckFunDef :: QName -> a -> tcErr -> OutputConstraint_boot tcErr a b
CheckLock :: b -> b -> OutputConstraint_boot tcErr a b
DataSort :: QName -> b -> OutputConstraint_boot tcErr a b
UsableAtMod :: Modality -> b -> OutputConstraint_boot tcErr a b

-- | A subset of <tt>OutputConstraint</tt>.
data OutputConstraint' a b
OfType' :: b -> a -> OutputConstraint' a b
[ofName] :: OutputConstraint' a b -> b
[ofExpr] :: OutputConstraint' a b -> a
data OutputContextEntry name ty val
ContextVar :: name -> ty -> OutputContextEntry name ty val
ContextLet :: name -> ty -> val -> OutputContextEntry name ty val
instance GHC.Show.Show Agda.Interaction.Base.CurrentFile
instance GHC.Show.Show a => GHC.Show.Show (Agda.Interaction.Base.Command' a)
instance GHC.Read.Read Agda.Interaction.Base.Remove
instance GHC.Show.Show Agda.Interaction.Base.Remove
instance GHC.Classes.Eq Agda.Interaction.Base.CompilerBackend
instance GHC.Classes.Ord Agda.Interaction.Base.Rewrite
instance GHC.Classes.Eq Agda.Interaction.Base.Rewrite
instance GHC.Read.Read Agda.Interaction.Base.Rewrite
instance GHC.Show.Show Agda.Interaction.Base.Rewrite
instance GHC.Classes.Eq Agda.Interaction.Base.ComputeMode
instance GHC.Read.Read Agda.Interaction.Base.ComputeMode
instance GHC.Show.Show Agda.Interaction.Base.ComputeMode
instance GHC.Show.Show Agda.Interaction.Base.UseForce
instance GHC.Read.Read Agda.Interaction.Base.UseForce
instance GHC.Classes.Eq Agda.Interaction.Base.UseForce
instance Data.Traversable.Traversable Agda.Interaction.Base.Interaction'
instance Data.Foldable.Foldable Agda.Interaction.Base.Interaction'
instance GHC.Base.Functor Agda.Interaction.Base.Interaction'
instance GHC.Read.Read range => GHC.Read.Read (Agda.Interaction.Base.Interaction' range)
instance GHC.Show.Show range => GHC.Show.Show (Agda.Interaction.Base.Interaction' range)
instance Data.Traversable.Traversable Agda.Interaction.Base.IOTCM'
instance Data.Foldable.Foldable Agda.Interaction.Base.IOTCM'
instance GHC.Base.Functor Agda.Interaction.Base.IOTCM'
instance GHC.Read.Read range => GHC.Read.Read (Agda.Interaction.Base.IOTCM' range)
instance GHC.Show.Show range => GHC.Show.Show (Agda.Interaction.Base.IOTCM' range)
instance GHC.Base.Functor (Agda.Interaction.Base.OutputConstraint_boot tcErr a)
instance GHC.Base.Functor (Agda.Interaction.Base.OutputForm_boot tcErr a)
instance GHC.Show.Show Agda.Interaction.Base.CompilerBackend
instance Agda.Syntax.Common.Pretty.Pretty Agda.Interaction.Base.CompilerBackend
instance GHC.Read.Read Agda.Interaction.Base.CompilerBackend
instance GHC.Read.Read Agda.Syntax.Common.InteractionId
instance GHC.Read.Read a => GHC.Read.Read (Agda.Syntax.Position.Range' a)
instance GHC.Read.Read a => GHC.Read.Read (Agda.Syntax.Position.Interval' a)
instance GHC.Read.Read Agda.Utils.FileName.AbsolutePath
instance GHC.Read.Read Agda.Syntax.Position.RangeFile
instance GHC.Read.Read a => GHC.Read.Read (Agda.Syntax.Position.Position' a)


-- | Data type for all interactive responses
module Agda.Interaction.Response.Base

-- | Responses for any interactive interface
--   
--   Note that the response is given in pieces and incrementally, so the
--   user can have timely response even during long computations.
data Response_boot tcErr tcWarning warningsAndNonFatalErrors
Resp_HighlightingInfo :: HighlightingInfo -> RemoveTokenBasedHighlighting -> HighlightingMethod -> ModuleToSource -> Response_boot tcErr tcWarning warningsAndNonFatalErrors
Resp_Status :: Status -> Response_boot tcErr tcWarning warningsAndNonFatalErrors
Resp_JumpToError :: FilePath -> Int32 -> Response_boot tcErr tcWarning warningsAndNonFatalErrors
Resp_InteractionPoints :: [InteractionId] -> Response_boot tcErr tcWarning warningsAndNonFatalErrors
Resp_GiveAction :: InteractionId -> GiveResult -> Response_boot tcErr tcWarning warningsAndNonFatalErrors

-- | Response is list of printed clauses.
Resp_MakeCase :: InteractionId -> MakeCaseVariant -> [String] -> Response_boot tcErr tcWarning warningsAndNonFatalErrors

-- | Solution for one or more meta-variables.
Resp_SolveAll :: [(InteractionId, Expr)] -> Response_boot tcErr tcWarning warningsAndNonFatalErrors
Resp_Mimer :: InteractionId -> Maybe String -> Response_boot tcErr tcWarning warningsAndNonFatalErrors
Resp_DisplayInfo :: DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors -> Response_boot tcErr tcWarning warningsAndNonFatalErrors

-- | The integer is the message's debug level.
Resp_RunningInfo :: Int -> String -> Response_boot tcErr tcWarning warningsAndNonFatalErrors
Resp_ClearRunningInfo :: Response_boot tcErr tcWarning warningsAndNonFatalErrors

-- | Clear highlighting of the given kind.
Resp_ClearHighlighting :: TokenBased -> Response_boot tcErr tcWarning warningsAndNonFatalErrors

-- | A command sent when an abort command has completed successfully.
Resp_DoneAborting :: Response_boot tcErr tcWarning warningsAndNonFatalErrors

-- | A command sent when an exit command is about to be completed.
Resp_DoneExiting :: Response_boot tcErr tcWarning warningsAndNonFatalErrors

-- | Should token-based highlighting be removed in conjunction with the
--   application of new highlighting (in order to reduce the risk of
--   flicker)?
data RemoveTokenBasedHighlighting

-- | Yes, remove all token-based highlighting from the file.
RemoveHighlighting :: RemoveTokenBasedHighlighting

-- | No.
KeepHighlighting :: RemoveTokenBasedHighlighting

-- | There are two kinds of "make case" commands.
data MakeCaseVariant
Function :: MakeCaseVariant
ExtendedLambda :: MakeCaseVariant

-- | Info to display at the end of an interactive command
data DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors
Info_CompilationOk :: CompilerBackend -> warningsAndNonFatalErrors -> DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors
Info_Constraints :: [OutputForm_boot tcErr Expr Expr] -> DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors
Info_AllGoalsWarnings :: Goals_boot tcErr -> warningsAndNonFatalErrors -> DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors
Info_Time :: CPUTime -> DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors

-- | When an error message is displayed this constructor should be used, if
--   appropriate.
Info_Error :: Info_Error_boot tcErr tcWarning -> DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors
Info_Intro_NotFound :: DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors
Info_Intro_ConstructorUnknown :: [String] -> DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors

-- | <a>Info_Auto</a> denotes either an error or a success (when
--   <a>Resp_GiveAction</a> is present) TODO: split these into separate
--   constructors
Info_Auto :: String -> DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors
Info_ModuleContents :: [Name] -> Telescope -> [(Name, Type)] -> DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors
Info_SearchAbout :: [(Name, Type)] -> String -> DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors
Info_WhyInScope :: WhyInScopeData -> DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors
Info_NormalForm :: CommandState -> ComputeMode -> Maybe CPUTime -> Expr -> DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors
Info_InferredType :: CommandState -> Maybe CPUTime -> Expr -> DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors
Info_Context :: InteractionId -> [ResponseContextEntry] -> DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors
Info_Version :: DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors
Info_GoalSpecific :: InteractionId -> GoalDisplayInfo_boot tcErr -> DisplayInfo_boot tcErr tcWarning warningsAndNonFatalErrors
data GoalDisplayInfo_boot tcErr
Goal_HelperFunction :: OutputConstraint' Expr Expr -> GoalDisplayInfo_boot tcErr
Goal_NormalForm :: ComputeMode -> Expr -> GoalDisplayInfo_boot tcErr
Goal_GoalType :: Rewrite -> GoalTypeAux -> [ResponseContextEntry] -> [IPFace' Expr] -> [OutputForm_boot tcErr Expr Expr] -> GoalDisplayInfo_boot tcErr
Goal_CurrentGoal :: Rewrite -> GoalDisplayInfo_boot tcErr
Goal_InferredType :: Expr -> GoalDisplayInfo_boot tcErr

-- | Goals &amp; Warnings
type Goals_boot tcErr = ([OutputConstraint_boot tcErr Expr InteractionId], [OutputConstraint_boot tcErr Expr NamedMeta])

-- | Errors that goes into Info_Error
--   
--   When an error message is displayed this constructor should be used, if
--   appropriate.
data Info_Error_boot tcErr tcWarning
Info_GenericError :: tcErr -> Info_Error_boot tcErr tcWarning
Info_CompilationError :: [tcWarning] -> Info_Error_boot tcErr tcWarning
Info_HighlightingParseError :: InteractionId -> Info_Error_boot tcErr tcWarning
Info_HighlightingScopeCheckError :: InteractionId -> Info_Error_boot tcErr tcWarning

-- | Auxiliary information that comes with Goal Type
data GoalTypeAux
GoalOnly :: GoalTypeAux
GoalAndHave :: Expr -> [IPFace' Expr] -> GoalTypeAux
GoalAndElaboration :: Term -> GoalTypeAux

-- | Entry in context.
data ResponseContextEntry
ResponseContextEntry :: Name -> Name -> Arg Expr -> Maybe Expr -> NameInScope -> ResponseContextEntry

-- | The original concrete name.
[respOrigName] :: ResponseContextEntry -> Name

-- | The name reified from abstract syntax.
[respReifName] :: ResponseContextEntry -> Name

-- | The type.
[respType] :: ResponseContextEntry -> Arg Expr

-- | The value (if it is a let-bound variable)
[respLetValue] :: ResponseContextEntry -> Maybe Expr

-- | Whether the <a>respReifName</a> is in scope.
[respInScope] :: ResponseContextEntry -> NameInScope

-- | Status information.
data Status
Status :: Bool -> Bool -> Bool -> Status

-- | Are implicit arguments displayed?
[sShowImplicitArguments] :: Status -> Bool

-- | Are irrelevant arguments displayed?
[sShowIrrelevantArguments] :: Status -> Bool

-- | Has the module been successfully type checked?
[sChecked] :: Status -> Bool

-- | Give action result
--   
--   Comment derived from agda2-mode.el
--   
--   If <a>GiveResult</a> is 'Give_String s', then the goal is replaced by
--   <tt>s</tt>, and otherwise the text inside the goal is retained
--   (parenthesised if <a>GiveResult</a> is <a>Give_Paren</a>).
data GiveResult
Give_String :: String -> GiveResult
Give_Paren :: GiveResult
Give_NoParen :: GiveResult

module Agda.Compiler.Backend.Base
data Backend_boot tcm
[Backend] :: NFData opts => Backend'_boot tcm opts env menv mod def -> Backend_boot tcm
data Backend'_boot tcm opts env menv mod def
Backend' :: String -> Maybe String -> opts -> [OptDescr (Flag opts)] -> (opts -> Bool) -> (opts -> tcm env) -> (env -> IsMain -> Map TopLevelModuleName mod -> tcm ()) -> (env -> IsMain -> TopLevelModuleName -> Maybe FilePath -> tcm (Recompile menv mod)) -> (env -> menv -> IsMain -> TopLevelModuleName -> [def] -> tcm mod) -> (env -> menv -> IsMain -> Definition -> tcm def) -> Bool -> (QName -> tcm Bool) -> Backend'_boot tcm opts env menv mod def
[backendName] :: Backend'_boot tcm opts env menv mod def -> String

-- | Optional version information to be printed with <tt>--version</tt>.
[backendVersion] :: Backend'_boot tcm opts env menv mod def -> Maybe String

-- | Default options
[options] :: Backend'_boot tcm opts env menv mod def -> opts

-- | Backend-specific command-line flags. Should at minimum contain a flag
--   to enable the backend.
[commandLineFlags] :: Backend'_boot tcm opts env menv mod def -> [OptDescr (Flag opts)]

-- | Unless the backend has been enabled, <tt>runAgda</tt> will fall back
--   to vanilla Agda behaviour.
[isEnabled] :: Backend'_boot tcm opts env menv mod def -> opts -> Bool

-- | Called after type checking completes, but before compilation starts.
[preCompile] :: Backend'_boot tcm opts env menv mod def -> opts -> tcm env

-- | Called after module compilation has completed. The <tt>IsMain</tt>
--   argument is <tt>NotMain</tt> if the <tt>--no-main</tt> flag is
--   present.
[postCompile] :: Backend'_boot tcm opts env menv mod def -> env -> IsMain -> Map TopLevelModuleName mod -> tcm ()

-- | Called before compilation of each module. Gets the path to the
--   <tt>.agdai</tt> file to allow up-to-date checking of previously
--   written compilation results. Should return <tt>Skip m</tt> if
--   compilation is not required. Will be <tt>Nothing</tt> if only scope
--   checking.
[preModule] :: Backend'_boot tcm opts env menv mod def -> env -> IsMain -> TopLevelModuleName -> Maybe FilePath -> tcm (Recompile menv mod)

-- | Called after all definitions of a module have been compiled.
[postModule] :: Backend'_boot tcm opts env menv mod def -> env -> menv -> IsMain -> TopLevelModuleName -> [def] -> tcm mod

-- | Compile a single definition.
[compileDef] :: Backend'_boot tcm opts env menv mod def -> env -> menv -> IsMain -> Definition -> tcm def

-- | True if the backend works if <tt>--only-scope-checking</tt> is used.
[scopeCheckingSuffices] :: Backend'_boot tcm opts env menv mod def -> Bool

-- | The treeless compiler may ask the Backend if elements of the given
--   type maybe possibly erased. The answer should be <a>False</a> if the
--   compilation of the type is used by a third party, e.g. in a FFI
--   binding.
[mayEraseType] :: Backend'_boot tcm opts env menv mod def -> QName -> tcm Bool
data Recompile menv mod
Recompile :: menv -> Recompile menv mod
Skip :: mod -> Recompile menv mod
instance GHC.Generics.Generic (Agda.Compiler.Backend.Base.Backend'_boot tcm opts env menv mod def)
instance Control.DeepSeq.NFData (Agda.Compiler.Backend.Base.Backend_boot tcm)
instance Control.DeepSeq.NFData opts => Control.DeepSeq.NFData (Agda.Compiler.Backend.Base.Backend'_boot tcm opts env menv mod def)

module Agda.TypeChecking.Monad.Base
data Constraint
ValueCmp :: Comparison -> CompareAs -> Term -> Term -> Constraint
ValueCmpOnFace :: Comparison -> Term -> Type -> Term -> Term -> Constraint
ElimCmp :: [Polarity] -> [IsForced] -> Type -> Term -> [Elim] -> [Elim] -> Constraint
SortCmp :: Comparison -> Sort -> Sort -> Constraint
LevelCmp :: Comparison -> Level -> Level -> Constraint
HasBiggerSort :: Sort -> Constraint
HasPTSRule :: Dom Type -> Abs Sort -> Constraint

-- | Check that the sort <a>Term</a> of data type <a>QName</a> admits
--   data/record types. E.g., sorts <tt>IUniv</tt>, <tt>SizeUniv</tt> etc.
--   do not admit such constructions. See <a>checkDataSort</a>.
CheckDataSort :: QName -> Sort -> Constraint
CheckMetaInst :: MetaId -> Constraint
CheckType :: Type -> Constraint

-- | Meta created for a term blocked by a postponed type checking problem
--   or unsolved constraints. The <a>MetaInstantiation</a> for the meta
--   (when unsolved) is either <a>BlockedConst</a> or
--   <a>PostponedTypeCheckingProblem</a>.
UnBlock :: MetaId -> Constraint

-- | The range is the one of the absurd pattern.
IsEmpty :: Range -> Type -> Constraint

-- | Check that the <a>Term</a> is either not a SIZELT or a non-empty
--   SIZELT.
CheckSizeLtSat :: Term -> Constraint

-- | the first argument is the instance argument and the second one is the
--   list of candidates (or Nothing if we haven’t determined the list of
--   candidates yet)
FindInstance :: MetaId -> Maybe [Candidate] -> Constraint

-- | Resolve the head symbol of the type that the given instance targets
ResolveInstanceHead :: QName -> Constraint

-- | Last argument is the error causing us to postpone.
CheckFunDef :: DefInfo -> QName -> [Clause] -> TCErr -> Constraint

-- | First argument is computation and the others are hole and goal type
UnquoteTactic :: Term -> Term -> Type -> Constraint

-- | <tt>CheckLockedVars t ty lk lk_ty</tt> with <tt>t : ty</tt>, <tt>lk :
--   lk_ty</tt> and <tt>t lk</tt> well-typed.
CheckLockedVars :: Term -> Type -> Arg Term -> Type -> Constraint

-- | Is the term usable at the given modality? This check should run if the
--   <tt>Sort</tt> is <tt>Nothing</tt> or <tt>isFibrant</tt>.
UsableAtModality :: WhyCheckModality -> Maybe Sort -> Modality -> Term -> Constraint
data TypeError
InternalError :: String -> TypeError
NotImplemented :: String -> TypeError
NotSupported :: String -> TypeError
CompilationError :: String -> TypeError
PropMustBeSingleton :: TypeError
DataMustEndInSort :: Term -> TypeError

-- | The target of a constructor isn't an application of its datatype. The
--   <a>Type</a> records what it does target.
ShouldEndInApplicationOfTheDatatype :: Type -> TypeError

-- | The target of a constructor isn't its datatype applied to something
--   that isn't the parameters. First term is the correct target and the
--   second term is the actual target.
ShouldBeAppliedToTheDatatypeParameters :: Term -> Term -> TypeError

-- | Expected a type to be an application of a particular datatype.
ShouldBeApplicationOf :: Type -> QName -> TypeError

-- | constructor, datatype
ConstructorPatternInWrongDatatype :: QName -> QName -> TypeError

-- | Datatype, constructors.
CantResolveOverloadedConstructorsTargetingSameDatatype :: QName -> List1 QName -> TypeError

-- | constructor, type
DoesNotConstructAnElementOf :: QName -> Type -> TypeError

-- | The left hand side of a function definition has a hidden argument
--   where a non-hidden was expected.
WrongHidingInLHS :: TypeError

-- | Expected a non-hidden function and found a hidden lambda.
WrongHidingInLambda :: Type -> TypeError

-- | A function is applied to a hidden argument where a non-hidden was
--   expected.
WrongHidingInApplication :: Type -> TypeError
WrongHidingInProjection :: QName -> TypeError
IllegalHidingInPostfixProjection :: NamedArg Expr -> TypeError

-- | A function is applied to a hidden named argument it does not have. The
--   list contains names of possible hidden arguments at this point.
WrongNamedArgument :: NamedArg Expr -> [NamedName] -> TypeError

-- | Wrong user-given relevance annotation in lambda.
WrongIrrelevanceInLambda :: TypeError

-- | Wrong user-given quantity annotation in lambda.
WrongQuantityInLambda :: TypeError

-- | Wrong user-given cohesion annotation in lambda.
WrongCohesionInLambda :: TypeError

-- | The given quantity does not correspond to the expected quantity.
QuantityMismatch :: Quantity -> Quantity -> TypeError

-- | The given hiding does not correspond to the expected hiding.
HidingMismatch :: Hiding -> Hiding -> TypeError

-- | The given relevance does not correspond to the expected relevane.
RelevanceMismatch :: Relevance -> Relevance -> TypeError
UninstantiatedDotPattern :: Expr -> TypeError
ForcedConstructorNotInstantiated :: Pattern -> TypeError
IllformedProjectionPatternAbstract :: Pattern -> TypeError
IllformedProjectionPatternConcrete :: Pattern -> TypeError
CannotEliminateWithPattern :: Maybe Blocker -> NamedArg Pattern -> Type -> TypeError
CannotEliminateWithProjection :: Arg Type -> Bool -> QName -> TypeError
WrongNumberOfConstructorArguments :: QName -> Nat -> Nat -> TypeError
ShouldBeEmpty :: Type -> [DeBruijnPattern] -> TypeError

-- | The given type should have been a sort.
ShouldBeASort :: Type -> TypeError

-- | The given type should have been a pi.
ShouldBePi :: Type -> TypeError
ShouldBePath :: Type -> TypeError
ShouldBeRecordType :: Type -> TypeError
ShouldBeRecordPattern :: DeBruijnPattern -> TypeError
NotAProjectionPattern :: NamedArg Pattern -> TypeError
NotAProperTerm :: TypeError

-- | This sort is not a type expression.
InvalidTypeSort :: Sort -> TypeError

-- | This term is not a type expression.
InvalidType :: Term -> TypeError
SplitOnCoinductive :: TypeError
SplitOnIrrelevant :: Dom Type -> TypeError
SplitOnUnusableCohesion :: Dom Type -> TypeError
SplitOnNonVariable :: Term -> Type -> TypeError
SplitOnNonEtaRecord :: QName -> TypeError
SplitOnAbstract :: QName -> TypeError
SplitOnUnchecked :: QName -> TypeError
SplitOnPartial :: Dom Type -> TypeError
SplitInProp :: DataOrRecordE -> TypeError
DefinitionIsIrrelevant :: QName -> TypeError
DefinitionIsErased :: QName -> TypeError
ProjectionIsIrrelevant :: QName -> TypeError
VariableIsIrrelevant :: Name -> TypeError
VariableIsErased :: Name -> TypeError
VariableIsOfUnusableCohesion :: Name -> Cohesion -> TypeError
UnequalLevel :: Comparison -> Level -> Level -> TypeError
UnequalTerms :: Comparison -> Term -> Term -> CompareAs -> TypeError
UnequalTypes :: Comparison -> Type -> Type -> TypeError

-- | The two function types have different relevance.
UnequalRelevance :: Comparison -> Term -> Term -> TypeError

-- | The two function types have different relevance.
UnequalQuantity :: Comparison -> Term -> Term -> TypeError

-- | The two function types have different cohesion.
UnequalCohesion :: Comparison -> Term -> Term -> TypeError

-- | One of the function types has a finite domain (i.e. is a
--   <tt>Partia</tt>l@) and the other isonot.
UnequalFiniteness :: Comparison -> Term -> Term -> TypeError

-- | The two function types have different hiding.
UnequalHiding :: Term -> Term -> TypeError
UnequalSorts :: Sort -> Sort -> TypeError
UnequalBecauseOfUniverseConflict :: Comparison -> Term -> Term -> TypeError
NotLeqSort :: Sort -> Sort -> TypeError

-- | The arguments are the meta variable and the parameter that it wants to
--   depend on.
MetaCannotDependOn :: MetaId -> Nat -> TypeError
MetaOccursInItself :: MetaId -> TypeError
MetaIrrelevantSolution :: MetaId -> Term -> TypeError
MetaErasedSolution :: MetaId -> Term -> TypeError
GenericError :: String -> TypeError
GenericDocError :: Doc -> TypeError

-- | the meta is what we might be blocked on.
SortOfSplitVarError :: Maybe Blocker -> Doc -> TypeError
BuiltinMustBeConstructor :: BuiltinId -> Expr -> TypeError
NoSuchBuiltinName :: String -> TypeError
DuplicateBuiltinBinding :: BuiltinId -> Term -> Term -> TypeError
NoBindingForBuiltin :: BuiltinId -> TypeError
NoBindingForPrimitive :: PrimitiveId -> TypeError
NoSuchPrimitiveFunction :: String -> TypeError
DuplicatePrimitiveBinding :: PrimitiveId -> QName -> QName -> TypeError
WrongArgInfoForPrimitive :: PrimitiveId -> ArgInfo -> ArgInfo -> TypeError
ShadowedModule :: Name -> [ModuleName] -> TypeError
BuiltinInParameterisedModule :: BuiltinId -> TypeError

-- | The declaration list comes from a single <a>NiceDeclaration</a>.
IllegalDeclarationInDataDefinition :: [Declaration] -> TypeError
IllegalLetInTelescope :: TypedBinding -> TypeError
IllegalPatternInTelescope :: Binder -> TypeError
NoRHSRequiresAbsurdPattern :: [NamedArg Pattern] -> TypeError

-- | Record type, fields not supplied by user, non-fields but supplied.
TooManyFields :: QName -> [Name] -> [Name] -> TypeError
DuplicateFields :: [Name] -> TypeError
DuplicateConstructors :: [Name] -> TypeError
DuplicateOverlapPragma :: QName -> OverlapMode -> OverlapMode -> TypeError
WithOnFreeVariable :: Expr -> Term -> TypeError
UnexpectedWithPatterns :: [Pattern] -> TypeError
WithClausePatternMismatch :: Pattern -> NamedArg DeBruijnPattern -> TypeError
IllTypedPatternAfterWithAbstraction :: Pattern -> TypeError
FieldOutsideRecord :: TypeError
ModuleArityMismatch :: ModuleName -> Telescope -> [NamedArg Expr] -> TypeError
GeneralizeCyclicDependency :: TypeError
GeneralizeUnsolvedMeta :: TypeError

-- | The first term references the given list of variables, which are in
--   "the future" with respect to the given lock (and its leftmost
--   variable)
ReferencesFutureVariables :: Term -> NonEmpty Int -> Arg Term -> Int -> TypeError

-- | Arguments: later term, its type, lock term. The lock term does not
--   mention any @lock variables.
DoesNotMentionTicks :: Term -> Type -> Arg Term -> TypeError
MismatchedProjectionsError :: QName -> QName -> TypeError
AttributeKindNotEnabled :: String -> String -> String -> TypeError
InvalidProjectionParameter :: NamedArg Expr -> TypeError
TacticAttributeNotAllowed :: TypeError
CannotRewriteByNonEquation :: Type -> TypeError
MacroResultTypeMismatch :: Type -> TypeError
NamedWhereModuleInRefinedContext :: [Term] -> [String] -> TypeError
CubicalPrimitiveNotFullyApplied :: QName -> TypeError
TooManyArgumentsToLeveledSort :: QName -> TypeError
TooManyArgumentsToUnivOmega :: QName -> TypeError
ComatchingDisabledForRecord :: QName -> TypeError
BuiltinMustBeIsOne :: Term -> TypeError
IncorrectTypeForRewriteRelation :: Term -> IncorrectTypeForRewriteRelationReason -> TypeError
UnexpectedParameter :: LamBinding -> TypeError
NoParameterOfName :: ArgName -> TypeError
UnexpectedModalityAnnotationInParameter :: LamBinding -> TypeError
ExpectedBindingForParameter :: Dom Type -> Abs Type -> TypeError
UnexpectedTypeSignatureForParameter :: List1 (NamedArg Binder) -> TypeError
SortDoesNotAdmitDataDefinitions :: QName -> Sort -> TypeError
SortCannotDependOnItsIndex :: QName -> Type -> TypeError
UnusableAtModality :: WhyCheckModality -> Modality -> Term -> TypeError
SplitError :: SplitError -> TypeError
ImpossibleConstructor :: QName -> NegativeUnification -> TypeError
TooManyPolarities :: QName -> Int -> TypeError

-- | A record type inferred as recursive needs a manual declaration whether
--   it should be inductively or coinductively. Sized type errors
RecursiveRecordNeedsInductivity :: QName -> TypeError

-- | The list of constraints is given redundantly as pairs of
--   <a>ProblemConstraint</a> (original constraint) and
--   <a>HypSizeConstraint</a> (form with size assumptions in context
--   spelled out). The <a>Doc</a> is some extra reason for why solving
--   failed.
CannotSolveSizeConstraints :: List1 (ProblemConstraint, HypSizeConstraint) -> Doc -> TypeError
ContradictorySizeConstraint :: (ProblemConstraint, HypSizeConstraint) -> TypeError

-- | This type, representing a type of sizes, might be empty.
EmptyTypeOfSizes :: Term -> TypeError

-- | This term, a function type constructor, lives in <tt>SizeUniv</tt>,
--   which is not allowed. Import errors
FunctionTypeInSizeUniv :: Term -> TypeError

-- | Collected errors when processing the <tt>.agda-lib</tt> file.
LibraryError :: LibErrors -> TypeError
LocalVsImportedModuleClash :: ModuleName -> TypeError

-- | Some interaction points (holes) have not been filled by user. There
--   are not <tt>UnsolvedMetas</tt> since unification solved them. This is
--   an error, since interaction points are never filled without user
--   interaction.
SolvedButOpenHoles :: TypeError
CyclicModuleDependency :: [TopLevelModuleName] -> TypeError
FileNotFound :: TopLevelModuleName -> [AbsolutePath] -> TypeError
OverlappingProjects :: AbsolutePath -> TopLevelModuleName -> TopLevelModuleName -> TypeError
AmbiguousTopLevelModuleName :: TopLevelModuleName -> [AbsolutePath] -> TypeError

-- | Found module name, expected module name.
ModuleNameUnexpected :: TopLevelModuleName -> TopLevelModuleName -> TypeError
ModuleNameDoesntMatchFileName :: TopLevelModuleName -> [AbsolutePath] -> TypeError
ClashingFileNamesFor :: ModuleName -> [AbsolutePath] -> TypeError

-- | Module name, file from which it was loaded, file which the include
--   path says contains the module.
ModuleDefinedInOtherFile :: TopLevelModuleName -> AbsolutePath -> AbsolutePath -> TypeError

-- | The file name does not correspond to a module name. Scope errors
InvalidFileName :: AbsolutePath -> InvalidFileNameReason -> TypeError
BothWithAndRHS :: TypeError
AbstractConstructorNotInScope :: QName -> TypeError
NotInScope :: [QName] -> TypeError
NoSuchModule :: QName -> TypeError
AmbiguousName :: QName -> AmbiguousNameReason -> TypeError
AmbiguousModule :: QName -> List1 ModuleName -> TypeError
AmbiguousField :: Name -> [ModuleName] -> TypeError
AmbiguousConstructor :: QName -> [QName] -> TypeError
ClashingDefinition :: QName -> QName -> Maybe NiceDeclaration -> TypeError
ClashingModule :: ModuleName -> ModuleName -> TypeError
ClashingImport :: Name -> QName -> TypeError
ClashingModuleImport :: Name -> ModuleName -> TypeError

-- | The given data/record definition rests in a different module than its
--   signature.
DefinitionInDifferentModule :: QName -> TypeError
DuplicateImports :: QName -> [ImportedName] -> TypeError
InvalidPattern :: Pattern -> TypeError
RepeatedVariablesInPattern :: [Name] -> TypeError
GeneralizeNotSupportedHere :: QName -> TypeError
GeneralizedVarInLetOpenedModule :: QName -> TypeError
MultipleFixityDecls :: [(Name, [Fixity'])] -> TypeError
MultiplePolarityPragmas :: [Name] -> TypeError

-- | The expr was used in the right hand side of an implicit module
--   definition, but it wasn't of the form <tt>m Delta</tt>.
NotAModuleExpr :: Expr -> TypeError
NotAnExpression :: Expr -> TypeError
NotAValidLetBinding :: NiceDeclaration -> TypeError
NotValidBeforeField :: NiceDeclaration -> TypeError
NothingAppliedToHiddenArg :: Expr -> TypeError
NothingAppliedToInstanceArg :: Expr -> TypeError
AsPatternInPatternSynonym :: TypeError
DotPatternInPatternSynonym :: TypeError
BadArgumentsToPatternSynonym :: AmbiguousQName -> TypeError
TooFewArgumentsToPatternSynonym :: AmbiguousQName -> TypeError
CannotResolveAmbiguousPatternSynonym :: List1 (QName, PatternSynDefn) -> TypeError

-- | This variable is bound in the lhs of the pattern synonym in instance
--   position, but not on the rhs. This is forbidden because expansion of
--   pattern synonyms would not be faithful to availability of instances in
--   instance search.
IllegalInstanceVariableInPatternSynonym :: Name -> TypeError

-- | A variable to be bound in the pattern synonym resolved on the rhs as
--   name of a constructor or a pattern synonym. The resolvents are given
--   in the list.
PatternSynonymArgumentShadowsConstructorOrPatternSynonym :: LHSOrPatSyn -> Name -> List1 AbstractName -> TypeError

-- | This variable is only bound on the lhs of the pattern synonym, not on
--   the rhs.
UnusedVariableInPatternSynonym :: Name -> TypeError

-- | These variables are only bound on the rhs of the pattern synonym, not
--   on the lhs. Operator errors
UnboundVariablesInPatternSynonym :: [Name] -> TypeError
NoParseForApplication :: List2 Expr -> TypeError
AmbiguousParseForApplication :: List2 Expr -> List1 Expr -> TypeError

-- | The list contains patterns that failed to be interpreted. If it is
--   non-empty, the first entry could be printed as error hint.
NoParseForLHS :: LHSOrPatSyn -> [Pattern] -> Pattern -> TypeError

-- | Pattern and its possible interpretations.
AmbiguousParseForLHS :: LHSOrPatSyn -> Pattern -> [Pattern] -> TypeError
AmbiguousProjection :: QName -> [QName] -> TypeError
AmbiguousOverloadedProjection :: List1 QName -> Doc -> TypeError
OperatorInformation :: [NotationSection] -> TypeError -> TypeError
InstanceNoCandidate :: Type -> [(Term, TCErr)] -> TypeError
UnquoteFailed :: UnquoteError -> TypeError
DeBruijnIndexOutOfScope :: Nat -> Telescope -> [Name] -> TypeError
NeedOptionCopatterns :: TypeError
NeedOptionRewriting :: TypeError
NeedOptionProp :: TypeError
NeedOptionTwoLevel :: TypeError
NonFatalErrors :: [TCWarning] -> TypeError
InstanceSearchDepthExhausted :: Term -> Type -> Int -> TypeError
TriedToCopyConstrainedPrim :: QName -> TypeError

-- | Used for backend-specific errors. The string is the backend name.
CustomBackendError :: String -> Doc -> TypeError
data Comparison
CmpEq :: Comparison
CmpLeq :: Comparison
data ModuleInfo
ModuleInfo :: Interface -> [TCWarning] -> Bool -> ModuleCheckMode -> ModuleInfo
[miInterface] :: ModuleInfo -> Interface

-- | Warnings were encountered when the module was type checked. These
--   might include warnings not stored in the interface itself,
--   specifically unsolved interaction metas. See
--   <a>Agda.Interaction.Imports</a>
[miWarnings] :: ModuleInfo -> [TCWarning]

-- | <a>True</a> if the module is a primitive module, which should always
--   be importable.
[miPrimitive] :: ModuleInfo -> Bool

-- | The <a>ModuleCheckMode</a> used to create the <a>Interface</a>
[miMode] :: ModuleInfo -> ModuleCheckMode
data Definition
Defn :: ArgInfo -> QName -> Type -> [Polarity] -> [Occurrence] -> NumGeneralizableArgs -> [Maybe Name] -> [LocalDisplayForm] -> MutualId -> CompiledRepresentation -> Maybe InstanceInfo -> Bool -> Set QName -> Bool -> Bool -> Bool -> Blocked_ -> !Language -> Defn -> Definition

-- | Hiding should not be used.
[defArgInfo] :: Definition -> ArgInfo

-- | The canonical name, used e.g. in compilation.
[defName] :: Definition -> QName

-- | Type of the lifted definition.
[defType] :: Definition -> Type

-- | Variance information on arguments of the definition. Does not include
--   info for dropped parameters to projection(-like) functions and
--   constructors.
[defPolarity] :: Definition -> [Polarity]

-- | Positivity information on arguments of the definition. Does not
--   include info for dropped parameters to projection(-like) functions and
--   constructors.
[defArgOccurrences] :: Definition -> [Occurrence]

-- | For a generalized variable, shows how many arguments should be
--   generalised.
[defArgGeneralizable] :: Definition -> NumGeneralizableArgs

-- | Gives the name of the (bound variable) parameter for named generalized
--   parameters. This is needed to bring it into scope when type checking
--   the data/record definition corresponding to a type with generalized
--   parameters.
[defGeneralizedParams] :: Definition -> [Maybe Name]
[defDisplay] :: Definition -> [LocalDisplayForm]
[defMutual] :: Definition -> MutualId
[defCompiledRep] :: Definition -> CompiledRepresentation

-- | <tt>Just q</tt> when this definition is an instance.
[defInstance] :: Definition -> Maybe InstanceInfo

-- | Has this function been created by a module instantiation?
[defCopy] :: Definition -> Bool

-- | The set of symbols with rewrite rules that match against this symbol
[defMatchable] :: Definition -> Set QName

-- | should compilers skip this? Used for e.g. cubical's comp
[defNoCompilation] :: Definition -> Bool

-- | Should the def be treated as injective by the pattern matching
--   unifier?
[defInjective] :: Definition -> Bool

-- | Is this a function defined by copatterns?
[defCopatternLHS] :: Definition -> Bool

-- | What blocking tag to use when we cannot reduce this def? Used when
--   checking a function definition is blocked on a meta in the type.
[defBlocked] :: Definition -> Blocked_

-- | The language used for the definition.
[defLanguage] :: Definition -> !Language
[theDef] :: Definition -> Defn
data Builtin pf
Builtin :: Term -> Builtin pf
Prim :: pf -> Builtin pf

-- | <tt>BUILTIN REWRITE</tt>. We can have several rewrite relations.
BuiltinRewriteRelations :: Set QName -> Builtin pf

-- | An alternative representation of partial elements in a telescope: Γ ⊢
--   λ Δ. [φ₁ u₁, ... , φₙ uₙ] : Δ → PartialP (∨_ᵢ φᵢ) T see cubicaltt
--   paper (however we do not store the type T).
data System
System :: Telescope -> [(Face, Term)] -> System

-- | the telescope Δ, binding vars for the clauses, Γ ⊢ Δ
[systemTel] :: System -> Telescope

-- | a system [φ₁ u₁, ... , φₙ uₙ] where Γ, Δ ⊢ φᵢ and Γ, Δ, φᵢ ⊢ uᵢ
[systemClauses] :: System -> [(Face, Term)]

-- | Type checking monad.
type TCM = TCMT IO
newtype ReduceM a
ReduceM :: (ReduceEnv -> a) -> ReduceM a
[unReduceM] :: ReduceM a -> ReduceEnv -> a

-- | How much highlighting should be sent to the user interface?
data HighlightingLevel
None :: HighlightingLevel
NonInteractive :: HighlightingLevel

-- | This includes both non-interactive highlighting and interactive
--   highlighting of the expression that is currently being type-checked.
Interactive :: HighlightingLevel

-- | How should highlighting be sent to the user interface?
data HighlightingMethod

-- | Via stdout.
Direct :: HighlightingMethod

-- | Both via files and via stdout.
Indirect :: HighlightingMethod

-- | Polarity for equality and subtype checking.
data Polarity

-- | monotone
Covariant :: Polarity

-- | antitone
Contravariant :: Polarity

-- | no information (mixed variance)
Invariant :: Polarity

-- | constant
Nonvariant :: Polarity

-- | A thing tagged with the context it came from. Also keeps the
--   substitution from previous checkpoints. This lets us handle the case
--   when an open thing was created in a context that we have since exited.
--   Remember which module it's from to make sure we don't get confused by
--   checkpoints from other files.
data Open a
OpenThing :: CheckpointId -> Map CheckpointId Substitution -> ModuleNameHash -> a -> Open a
[openThingCheckpoint] :: Open a -> CheckpointId
[openThingCheckpointMap] :: Open a -> Map CheckpointId Substitution
[openThingModule] :: Open a -> ModuleNameHash
[openThing] :: Open a -> a

-- | <tt>MetaInfo</tt> is cloned from one meta to the next during pruning.
data MetaInfo
MetaInfo :: Closure Range -> Modality -> RunMetaOccursCheck -> MetaNameSuggestion -> Arg DoGeneralize -> MetaInfo
[miClosRange] :: MetaInfo -> Closure Range

-- | Instantiable with irrelevant/erased solution?
[miModality] :: MetaInfo -> Modality

-- | Run the extended occurs check that goes in definitions?
[miMetaOccursCheck] :: MetaInfo -> RunMetaOccursCheck

-- | Used for printing. <tt>Just x</tt> if meta-variable comes from omitted
--   argument with name <tt>x</tt>.
[miNameSuggestion] :: MetaInfo -> MetaNameSuggestion

-- | Should this meta be generalized if unsolved? If so, at what ArgInfo?
[miGeneralizable] :: MetaInfo -> Arg DoGeneralize
type Constraints = [ProblemConstraint]

-- | Assorted warnings and errors to be displayed to the user
data WarningsAndNonFatalErrors
WarningsAndNonFatalErrors :: [TCWarning] -> [TCWarning] -> WarningsAndNonFatalErrors
[tcWarnings] :: WarningsAndNonFatalErrors -> [TCWarning]
[nonFatalErrors] :: WarningsAndNonFatalErrors -> [TCWarning]
data Signature
Sig :: Sections -> Definitions -> RewriteRuleMap -> InstanceTable -> Signature
[_sigSections] :: Signature -> Sections
[_sigDefinitions] :: Signature -> Definitions

-- | The rewrite rules defined in this file.
[_sigRewriteRules] :: Signature -> RewriteRuleMap
[_sigInstances] :: Signature -> InstanceTable

-- | A non-fatal error is an error which does not prevent us from checking
--   the document further and interacting with the user.
data Warning
NicifierIssue :: DeclarationWarning -> Warning
TerminationIssue :: [TerminationError] -> Warning

-- | `UnreachableClauses f rs` means that the clauses in <tt>f</tt> whose
--   ranges are rs are unreachable
UnreachableClauses :: QName -> [Range] -> Warning

-- | `CoverageIssue f pss` means that <tt>pss</tt> are not covered in
--   <tt>f</tt>
CoverageIssue :: QName -> [(Telescope, [NamedArg DeBruijnPattern])] -> Warning
CoverageNoExactSplit :: QName -> [Clause] -> Warning

-- | <a>Clause</a> was turned into copattern matching clause(s) by an
--   <tt>{-# INLINE constructor #-}</tt> and thus is not a definitional
--   equality any more.
InlineNoExactSplit :: QName -> Clause -> Warning
NotStrictlyPositive :: QName -> Seq OccursWhere -> Warning

-- | Checking whether constructor <a>QName</a> <a>Term</a> fits into
--   <tt>data</tt> <a>Term</a> produced <a>TCErr</a>
ConstructorDoesNotFitInData :: QName -> Sort -> Sort -> TCErr -> Warning

-- | A record type declared as both <tt>coinductive</tt> and having
--   <tt>eta-equality</tt>.
CoinductiveEtaRecord :: QName -> Warning

-- | Do not use directly with <tt>warning</tt>
UnsolvedMetaVariables :: [Range] -> Warning

-- | Do not use directly with <tt>warning</tt>
UnsolvedInteractionMetas :: [Range] -> Warning

-- | Do not use directly with <tt>warning</tt>
UnsolvedConstraints :: Constraints -> Warning

-- | Do not use directly with <tt>warning</tt>
InteractionMetaBoundaries :: [Range] -> Warning
CantGeneralizeOverSorts :: [MetaId] -> Warning
AbsurdPatternRequiresNoRHS :: [NamedArg DeBruijnPattern] -> Warning

-- | In `OldBuiltin old new`, the BUILTIN old has been replaced by new.
OldBuiltin :: BuiltinId -> BuiltinId -> Warning

-- | The builtin declares a new identifier, so it should not be in scope.
BuiltinDeclaresIdentifier :: BuiltinId -> Warning

-- | The given record directive is conflicting with a prior one in the same
--   record declaration.
DuplicateRecordDirective :: RecordDirective -> Warning

-- | If the user wrote just <tt>{-# REWRITE #-}</tt>.
EmptyRewritePragma :: Warning

-- | An empty <tt>where</tt> block is dead code.
EmptyWhere :: Warning

-- | If the user wrote something other than an unqualified name in the
--   <tt>as</tt> clause of an <tt>import</tt> statement. The <a>String</a>
--   gives optionally extra explanation.
IllformedAsClause :: String -> Warning

-- | A character literal Agda does not support, e.g. surrogate code points.
InvalidCharacterLiteral :: Char -> Warning

-- | If a <tt>renaming</tt> import directive introduces a name or module
--   name clash in the exported names of a module. (See issue #4154.)
ClashesViaRenaming :: NameOrModule -> [Name] -> Warning

-- | The 'pattern' declaration is useless in the presence of either
--   <tt>coinductive</tt> or <tt>eta-equality</tt>. Content of
--   <a>String</a> is "coinductive" or "eta", resp.
UselessPatternDeclarationForRecord :: String -> Warning

-- | Warning when pragma is useless and thus ignored. <a>Range'</a> is for
--   dead code highlighting.
UselessPragma :: Range -> Doc -> Warning

-- | If the user opens a module public before the module header. (See issue
--   #2377.)
UselessPublic :: Warning

-- | Names in <a>hiding</a> directive that don't hide anything imported by
--   a <a>using</a> directive.
UselessHiding :: [ImportedName] -> Warning
UselessInline :: QName -> Warning
WrongInstanceDeclaration :: Warning

-- | An instance was declared with an implicit argument, which means it
--   will never actually be considered by instance search.
InstanceWithExplicitArg :: QName -> Warning

-- | The type of an instance argument doesn't end in a named or variable
--   type, so it will never be considered by instance search.
InstanceNoOutputTypeName :: Doc -> Warning

-- | As InstanceWithExplicitArg, but for local bindings rather than
--   top-level instances.
InstanceArgWithExplicitArg :: Doc -> Warning

-- | The --inversion-max-depth was reached.
InversionDepthReached :: QName -> Warning

-- | A coinductive record was declared but neither --guardedness nor
--   --sized-types is enabled.
NoGuardednessFlag :: QName -> Warning
SafeFlagPostulate :: Name -> Warning

-- | Unsafe OPTIONS.
SafeFlagPragma :: [String] -> Warning
SafeFlagWithoutKFlagPrimEraseEquality :: Warning
WithoutKFlagPrimEraseEquality :: Warning

-- | `ConflictingPragmaOptions a b`: Inconsistent options `--a` and
--   `--no-b`, since `--a` implies `--b`. Ignoring `--no-b`.
ConflictingPragmaOptions :: String -> String -> Warning
OptionWarning :: OptionWarning -> Warning
ParseWarning :: ParseWarning -> Warning
LibraryWarning :: LibWarning -> Warning

-- | `DeprecationWarning old new version`: <tt>old</tt> is deprecated, use
--   <tt>new</tt> instead. This will be an error in Agda <tt>version</tt>.
DeprecationWarning :: String -> String -> String -> Warning

-- | User-defined warning (e.g. to mention that a name is deprecated)
UserWarning :: Text -> Warning

-- | Duplicate mentions of the same name in <tt>using</tt> directive(s).
DuplicateUsing :: List1 ImportedName -> Warning

-- | Fixity of modules cannot be changed via renaming (since modules have
--   no fixity).
FixityInRenamingModule :: List1 Range -> Warning

-- | Some imported names are not actually exported by the source module.
--   The second argument is the names that could be exported. The third
--   argument is the module names that could be exported.
ModuleDoesntExport :: QName -> [Name] -> [Name] -> [ImportedName] -> Warning

-- | Importing a file using an infective option into one which doesn't
InfectiveImport :: Doc -> Warning

-- | Importing a file not using a coinfective option from one which does
CoInfectiveImport :: Doc -> Warning

-- | Confluence checking incomplete because the definition of the
--   <a>QName</a> contains unsolved metavariables.
ConfluenceCheckingIncompleteBecauseOfMeta :: QName -> Warning

-- | Confluence checking with <tt>--cubical</tt> might be incomplete.
ConfluenceForCubicalNotSupported :: Warning
IllegalRewriteRule :: QName -> IllegalRewriteRuleReason -> Warning

-- | Confluence checker found critical pair and equality checking resulted
--   in a type error
RewriteNonConfluent :: Term -> Term -> Term -> Doc -> Warning

-- | Confluence checker got stuck on computing overlap between two rewrite
--   rules
RewriteMaybeNonConfluent :: Term -> Term -> [Doc] -> Warning

-- | The global confluence checker found a term <tt>u</tt> that reduces to
--   both <tt>v1</tt> and <tt>v2</tt> and there is no rule to resolve the
--   ambiguity.
RewriteAmbiguousRules :: Term -> Term -> Term -> Warning

-- | The global confluence checker found a term <tt>u</tt> that reduces to
--   <tt>v</tt>, but <tt>v</tt> does not reduce to <tt>rho(u)</tt>.
RewriteMissingRule :: Term -> Term -> Term -> Warning

-- | COMPILE directive for an erased symbol.
PragmaCompileErased :: BackendName -> QName -> Warning

-- | <tt>COMPILE GHC</tt> pragma for lists; ignored.
PragmaCompileList :: Warning

-- | <tt>COMPILE GHC</tt> pragma for <tt>MAYBE</tt>; ignored.
PragmaCompileMaybe :: Warning

-- | Compiler run on module that does not have a <tt>main</tt> function.
NoMain :: TopLevelModuleName -> Warning

-- | Out of scope error we can recover from.
NotInScopeW :: [QName] -> Warning

-- | Was not able to compute a full equivalence when splitting.
UnsupportedIndexedMatch :: Doc -> Warning

-- | The as-name in an as-pattern may not shadow a constructor
--   (<a>IsLHS</a>) or pattern synonym name (<a>IsPatSyn</a>), because this
--   can be confusing to read.
AsPatternShadowsConstructorOrPatternSynonym :: LHSOrPatSyn -> Warning

-- | A pattern variable has the name of a constructor (data constructor or
--   matchable record constructor).
PatternShadowsConstructor :: Name -> QName -> Warning

-- | Explicit use of @<tt>ω</tt> or @<tt>plenty</tt> in hard compile-time
--   mode.
PlentyInHardCompileTimeMode :: QωOrigin -> Warning
RecordFieldWarning :: RecordFieldWarning -> Warning

-- | An <tt>abstract</tt> or <tt>opaque</tt> definition lacks a type
--   signature.
MissingTypeSignatureForOpaque :: QName -> IsOpaque -> Warning
NotAffectedByOpaque :: Warning
UnfoldTransparentName :: QName -> Warning
UselessOpaque :: Warning

-- | Face constraint patterns <tt>(i = 0)</tt> must be visible arguments.
FaceConstraintCannotBeHidden :: ArgInfo -> Warning

-- | Face constraint patterns <tt>(i = 0)</tt> must be unnamed arguments.
FaceConstraintCannotBeNamed :: NamedName -> Warning

-- | `DuplicateInterfaceFiles selectedInterfaceFile ignoredInterfaceFile`
DuplicateInterfaceFiles :: AbsolutePath -> AbsolutePath -> Warning

-- | Used for backend-specific warnings. The string is the backend name.
CustomBackendWarning :: String -> Doc -> Warning

-- | Type-checking errors.
data TCErr
TypeError :: CallStack -> TCState -> Closure TypeError -> TCErr

-- | Location in the internal Agda source code where the error was raised
[tcErrLocation] :: TCErr -> CallStack

-- | The state in which the error was raised.
[tcErrState] :: TCErr -> TCState

-- | The environment in which the error as raised plus the error.
[tcErrClosErr] :: TCErr -> Closure TypeError
Exception :: Range -> Doc -> TCErr

-- | The first argument is the state in which the error was raised.
IOException :: TCState -> Range -> IOException -> TCErr

-- | The exception which is usually caught. Raised for pattern violations
--   during unification (<tt>assignV</tt>) but also in other situations
--   where we want to backtrack. Contains an unblocker to control when the
--   computation should be retried.
PatternErr :: Blocker -> TCErr
data TCWarning
TCWarning :: CallStack -> Range -> Warning -> Doc -> Bool -> TCWarning

-- | Location in the internal Agda source code location where the error
--   raised
[tcWarningLocation] :: TCWarning -> CallStack

-- | Range where the warning was raised
[tcWarningRange] :: TCWarning -> Range

-- | The warning itself
[tcWarning] :: TCWarning -> Warning

-- | The warning printed in the state and environment where it was raised
[tcWarningPrintedWarning] :: TCWarning -> Doc

-- | Should the warning be affected by caching.
[tcWarningCached] :: TCWarning -> Bool

-- | For printing, we couple a meta with its name suggestion.
data NamedMeta
NamedMeta :: MetaNameSuggestion -> MetaId -> NamedMeta
[nmSuggestion] :: NamedMeta -> MetaNameSuggestion
[nmid] :: NamedMeta -> MetaId

-- | Maps top-level module names to the corresponding source file names.
type ModuleToSource = Map TopLevelModuleName AbsolutePath
type Definitions = HashMap QName Definition

-- | Callback fuction to call when there is a response to give to the
--   interactive frontend.
--   
--   Note that the response is given in pieces and incrementally, so the
--   user can have timely response even during long computations.
--   
--   Typical <a>InteractionOutputCallback</a> functions:
--   
--   <ul>
--   <li>Convert the response into a <a>String</a> representation and print
--   it on standard output (suitable for inter-process communication).</li>
--   <li>Put the response into a mutable variable stored in the closure of
--   the <a>InteractionOutputCallback</a> function. (suitable for
--   intra-process communication).</li>
--   </ul>
type InteractionOutputCallback = Response_boot TCErr TCWarning WarningsAndNonFatalErrors -> TCM ()

-- | Datatype representing a single boundary condition: x_0 = u_0, ... ,x_n
--   = u_n ⊢ t = ?n es
data IPFace' t
IPFace' :: [(t, t)] -> t -> IPFace' t
[faceEqns] :: IPFace' t -> [(t, t)]
[faceRHS] :: IPFace' t -> t

-- | <tt>MonadTCEnv</tt> made into its own dedicated service class. This
--   allows us to use <a>MonadReader</a> for <a>ReaderT</a> extensions of
--   <tt>TCM</tt>.
class Monad m => MonadTCEnv m
askTC :: MonadTCEnv m => m TCEnv
localTC :: MonadTCEnv m => (TCEnv -> TCEnv) -> m a -> m a
askTC :: (MonadTCEnv m, MonadTrans t, MonadTCEnv n, t n ~ m) => m TCEnv
localTC :: (MonadTCEnv m, MonadTransControl t, MonadTCEnv n, t n ~ m) => (TCEnv -> TCEnv) -> m a -> m a

-- | Embedding a TCM computation.
class (Applicative tcm, MonadIO tcm, MonadTCEnv tcm, MonadTCState tcm, HasOptions tcm) => MonadTCM tcm
liftTCM :: MonadTCM tcm => TCM a -> tcm a
liftTCM :: (MonadTCM tcm, MonadTCM m, MonadTrans t, tcm ~ t m) => TCM a -> tcm a

-- | <tt>MonadTCState</tt> made into its own dedicated service class. This
--   allows us to use <a>MonadState</a> for <a>StateT</a> extensions of
--   <tt>TCM</tt>.
class Monad m => MonadTCState m
getTC :: MonadTCState m => m TCState
putTC :: MonadTCState m => TCState -> m ()
modifyTC :: MonadTCState m => (TCState -> TCState) -> m ()
getTC :: (MonadTCState m, MonadTrans t, MonadTCState n, t n ~ m) => m TCState
putTC :: (MonadTCState m, MonadTrans t, MonadTCState n, t n ~ m) => TCState -> m ()
modifyTC :: (MonadTCState m, MonadTrans t, MonadTCState n, t n ~ m) => (TCState -> TCState) -> m ()
class Monad m => ReadTCState m
getTCState :: ReadTCState m => m TCState
locallyTCState :: ReadTCState m => Lens' TCState a -> (a -> a) -> m b -> m b
withTCState :: ReadTCState m => (TCState -> TCState) -> m a -> m a
getTCState :: (ReadTCState m, MonadTrans t, ReadTCState n, t n ~ m) => m TCState
locallyTCState :: (ReadTCState m, MonadTransControl t, ReadTCState n, t n ~ m) => Lens' TCState a -> (a -> a) -> m b -> m b

-- | The type checking monad transformer. Adds readonly <a>TCEnv</a> and
--   mutable <a>TCState</a>.
newtype TCMT m a
TCM :: (IORef TCState -> TCEnv -> m a) -> TCMT m a
[unTCM] :: TCMT m a -> IORef TCState -> TCEnv -> m a

-- | Distinguish error message when parsing lhs or pattern synonym, resp.
data LHSOrPatSyn
IsLHS :: LHSOrPatSyn
IsPatSyn :: LHSOrPatSyn

-- | A <tt>DisplayForm</tt> is in essence a rewrite rule <tt>q ts --&gt;
--   dt</tt> for a defined symbol (could be a constructor as well)
--   <tt>q</tt>. The right hand side is a <a>DisplayTerm</a> which is used
--   to <tt>reify</tt> to a more readable <a>Syntax</a>.
--   
--   The patterns <tt>ts</tt> are just terms, but the first
--   <tt>dfPatternVars</tt> variables are pattern variables that matches
--   any term.
data DisplayForm
Display :: Nat -> Elims -> DisplayTerm -> DisplayForm

-- | Number <tt>n</tt> of pattern variables in <a>dfPats</a>.
[dfPatternVars] :: DisplayForm -> Nat

-- | Left hand side patterns, the <tt>n</tt> first free variables are
--   pattern variables, any variables above <tt>n</tt> are fixed and only
--   match that particular variable. This happens when you have display
--   forms inside parameterised modules that match on the module
--   parameters. The <a>ArgInfo</a> is ignored in these patterns.
[dfPats] :: DisplayForm -> Elims

-- | Right hand side.
[dfRHS] :: DisplayForm -> DisplayTerm
data Call
CheckClause :: Type -> SpineClause -> Call
CheckLHS :: SpineLHS -> Call
CheckPattern :: Pattern -> Telescope -> Type -> Call
CheckPatternLinearityType :: Name -> Call
CheckPatternLinearityValue :: Name -> Call
CheckLetBinding :: LetBinding -> Call
InferExpr :: Expr -> Call
CheckExprCall :: Comparison -> Expr -> Type -> Call
CheckDotPattern :: Expr -> Term -> Call
CheckProjection :: Range -> QName -> Type -> Call
IsTypeCall :: Comparison -> Expr -> Sort -> Call
IsType_ :: Expr -> Call
InferVar :: Name -> Call
InferDef :: QName -> Call
CheckArguments :: Range -> [NamedArg Expr] -> Type -> Maybe Type -> Call
CheckMetaSolution :: Range -> MetaId -> Type -> Term -> Call
CheckTargetType :: Range -> Type -> Type -> Call
CheckDataDef :: Range -> QName -> [LamBinding] -> [Constructor] -> Call
CheckRecDef :: Range -> QName -> [LamBinding] -> [Constructor] -> Call
CheckConstructor :: QName -> Telescope -> Sort -> Constructor -> Call
CheckConArgFitsIn :: QName -> Bool -> Type -> Sort -> Call

-- | Highlight (interactively) if and only if the boolean is <a>True</a>.
CheckFunDefCall :: Range -> QName -> [Clause] -> Bool -> Call
CheckPragma :: Range -> Pragma -> Call
CheckPrimitive :: Range -> QName -> Expr -> Call
CheckIsEmpty :: Range -> Type -> Call
CheckConfluence :: QName -> QName -> Call
CheckModuleParameters :: ModuleName -> Telescope -> Call
CheckWithFunctionType :: Type -> Call
CheckSectionApplication :: Range -> Erased -> ModuleName -> ModuleApplication -> Call
CheckNamedWhere :: ModuleName -> Call

-- | Checking a clause for confluence with endpoint reductions. Always
--   <tt>φ ⊢ f vs = rhs</tt> for now, but we store the simplifications of
--   <tt>f vs[φ]</tt> and <tt>rhs[φ]</tt>.
CheckIApplyConfluence :: Range -> QName -> Term -> Term -> Term -> Type -> Call
ScopeCheckExpr :: Expr -> Call
ScopeCheckDeclaration :: NiceDeclaration -> Call
ScopeCheckLHS :: QName -> Pattern -> Call
NoHighlighting :: Call

-- | Interaction command: show module contents.
ModuleContents :: Call

-- | used by <tt>setCurrentRange</tt>
SetRange :: Range -> Call
data Closure a
Closure :: Signature -> TCEnv -> ScopeInfo -> Map ModuleName CheckpointId -> a -> Closure a
[clSignature] :: Closure a -> Signature
[clEnv] :: Closure a -> TCEnv
[clScope] :: Closure a -> ScopeInfo
[clModuleCheckpoints] :: Closure a -> Map ModuleName CheckpointId
[clValue] :: Closure a -> a
class (Applicative m, MonadTCEnv m, ReadTCState m, HasOptions m) => MonadReduce m
liftReduce :: MonadReduce m => ReduceM a -> m a
liftReduce :: (MonadReduce m, MonadTrans t, MonadReduce n, t n ~ m) => ReduceM a -> m a
type Statistics = Map String Integer

-- | The backends are responsible for parsing their own pragmas.
data CompilerPragma
CompilerPragma :: Range -> String -> CompilerPragma
data TCEnv
TCEnv :: Context -> LetBindings -> ModuleName -> Maybe AbsolutePath -> [(ModuleName, Nat)] -> [TopLevelModuleName] -> Maybe MutualId -> TerminationCheck () -> CoverageCheck -> Bool -> Bool -> Bool -> Bool -> Bool -> Set ProblemId -> Maybe ProblemId -> AbstractMode -> Relevance -> Quantity -> Bool -> Bool -> Bool -> Bool -> Range -> Range -> IPClause -> Maybe (Closure Call) -> HighlightingLevel -> HighlightingMethod -> ExpandHidden -> Maybe QName -> Simplification -> AllowedReductions -> ReduceDefs -> Bool -> Int -> Bool -> Bool -> Bool -> Bool -> UnquoteFlags -> !Int -> Bool -> [QName] -> Bool -> CheckpointId -> Map CheckpointId Substitution -> DoGeneralize -> Map QName GeneralizedValue -> Maybe BackendName -> Bool -> Bool -> !Maybe Int -> !Maybe OpaqueId -> TCEnv
[envContext] :: TCEnv -> Context
[envLetBindings] :: TCEnv -> LetBindings
[envCurrentModule] :: TCEnv -> ModuleName

-- | The path to the file that is currently being type-checked.
--   <a>Nothing</a> if we do not have a file (like in interactive mode see
--   <tt>CommandLine</tt>).
[envCurrentPath] :: TCEnv -> Maybe AbsolutePath

-- | anonymous modules and their number of free variables
[envAnonymousModules] :: TCEnv -> [(ModuleName, Nat)]

-- | The module stack with the entry being the top-level module as Agda
--   chases modules. It will be empty if there is no main module, will have
--   a single entry for the top level module, or more when descending past
--   the main module. This is used to detect import cycles and in some
--   cases highlighting behavior. The level of a given module is not
--   necessarily the same as the length, in the module dependency graph, of
--   the shortest path from the top-level module; it depends on in which
--   order Agda chooses to chase dependencies.
[envImportPath] :: TCEnv -> [TopLevelModuleName]

-- | the current (if any) mutual block
[envMutualBlock] :: TCEnv -> Maybe MutualId

-- | are we inside the scope of a termination pragma
[envTerminationCheck] :: TCEnv -> TerminationCheck ()

-- | are we inside the scope of a coverage pragma
[envCoverageCheck] :: TCEnv -> CoverageCheck

-- | are we inside a make-case (if so, ignore forcing analysis in unifier)
[envMakeCase] :: TCEnv -> Bool

-- | Are we currently in the process of solving active constraints?
[envSolvingConstraints] :: TCEnv -> Bool

-- | Have we stepped into the where-declarations of a clause? Everything
--   under a <tt>where</tt> will be checked with this flag on.
[envCheckingWhere] :: TCEnv -> Bool

-- | Are we working on types? Turned on by <tt>workOnTypes</tt>.
[envWorkingOnTypes] :: TCEnv -> Bool

-- | Are we allowed to assign metas?
[envAssignMetas] :: TCEnv -> Bool
[envActiveProblems] :: TCEnv -> Set ProblemId

-- | If inside a <tt>runUnquoteM</tt> call, stores the top-level problem id
--   assigned to the invokation. We use this to decide which instance
--   constraints originate from the current call and which come from the
--   outside, for the purpose of a <tt>solveInstanceConstraints</tt> inside
--   <tt>noConstraints</tt> only failing for local instance constraints.
[envUnquoteProblem] :: TCEnv -> Maybe ProblemId

-- | When checking the typesignature of a public definition or the body of
--   a non-abstract definition this is true. To prevent information about
--   abstract things leaking outside the module.
[envAbstractMode] :: TCEnv -> AbstractMode

-- | Are we checking an irrelevant argument? (=<tt>Irrelevant</tt>) Then
--   top-level irrelevant declarations are enabled. Other value:
--   <tt>Relevant</tt>, then only relevant decls. are available.
[envRelevance] :: TCEnv -> Relevance

-- | Are we checking a runtime-irrelevant thing? (=<a>Quantity0</a>) Then
--   runtime-irrelevant things are usable.
[envQuantity] :: TCEnv -> Quantity

-- | Is the "hard" compile-time mode enabled? In this mode the quantity
--   component of the environment is always zero, and every new definition
--   is treated as erased.
[envHardCompileTimeMode] :: TCEnv -> Bool

-- | Are we currently case-splitting on a strict datatype (i.e. in SSet)?
--   If yes, the pattern-matching unifier will solve reflexive equations
--   even --without-K.
[envSplitOnStrict] :: TCEnv -> Bool

-- | Sometimes we want to disable display forms.
[envDisplayFormsEnabled] :: TCEnv -> Bool

-- | Fold let-bindings when printing terms (default: True)
[envFoldLetBindings] :: TCEnv -> Bool
[envRange] :: TCEnv -> Range

-- | Interactive highlighting uses this range rather than <a>envRange</a>.
[envHighlightingRange] :: TCEnv -> Range

-- | What is the current clause we are type-checking? Will be recorded in
--   interaction points in this clause.
[envClause] :: TCEnv -> IPClause

-- | what we're doing at the moment
[envCall] :: TCEnv -> Maybe (Closure Call)

-- | Set to <a>None</a> when imported modules are type-checked.
[envHighlightingLevel] :: TCEnv -> HighlightingLevel
[envHighlightingMethod] :: TCEnv -> HighlightingMethod

-- | When type-checking an alias f=e, we do not want to insert hidden
--   arguments in the end, because these will become unsolved metas.
[envExpandLast] :: TCEnv -> ExpandHidden

-- | We are reducing an application of this function. (For tracking of
--   incomplete matches.)
[envAppDef] :: TCEnv -> Maybe QName

-- | Did we encounter a simplification (proper match) during the current
--   reduction process?
[envSimplification] :: TCEnv -> Simplification
[envAllowedReductions] :: TCEnv -> AllowedReductions
[envReduceDefs] :: TCEnv -> ReduceDefs
[envReconstructed] :: TCEnv -> Bool

-- | Injectivity can cause non-termination for unsolvable contraints (#431,
--   #3067). Keep a limit on the nesting depth of injectivity uses.
[envInjectivityDepth] :: TCEnv -> Int

-- | When <tt>True</tt>, the conversion checker will consider all term
--   constructors as injective, including blocked function applications and
--   metas. Warning: this should only be used when not assigning any metas
--   (e.g. when <tt>envAssignMetas</tt> is <tt>False</tt> or when running
--   <tt>pureEqualTerms</tt>) or else we get non-unique meta solutions.
[envCompareBlocked] :: TCEnv -> Bool

-- | When <tt>True</tt>, types will be omitted from printed pi types if
--   they can be inferred.
[envPrintDomainFreePi] :: TCEnv -> Bool

-- | When <tt>True</tt>, throw away meta numbers and meta elims. This is
--   used for reifying terms for feeding into the user's source code, e.g.,
--   for the interaction tactics <tt>solveAll</tt>.
[envPrintMetasBare] :: TCEnv -> Bool

-- | Used by the scope checker to make sure that certain forms of
--   expressions are not used inside dot patterns: extended lambdas and
--   let-expressions.
[envInsideDotPattern] :: TCEnv -> Bool
[envUnquoteFlags] :: TCEnv -> UnquoteFlags

-- | Until we get a termination checker for instance search (#1743) we
--   limit the search depth to ensure termination.
[envInstanceDepth] :: TCEnv -> !Int
[envIsDebugPrinting] :: TCEnv -> Bool

-- | #3004: pattern lambdas with copatterns may refer to themselves. We
--   don't have a good story for what to do in this case, but at least
--   printing shouldn't loop. Here we keep track of which pattern lambdas
--   we are currently in the process of printing.
[envPrintingPatternLambdas] :: TCEnv -> [QName]

-- | Use call-by-need evaluation for reductions.
[envCallByNeed] :: TCEnv -> Bool

-- | Checkpoints track the evolution of the context as we go under binders
--   or refine it by pattern matching.
[envCurrentCheckpoint] :: TCEnv -> CheckpointId

-- | Keeps the substitution from each previous checkpoint to the current
--   context.
[envCheckpoints] :: TCEnv -> Map CheckpointId Substitution

-- | Should new metas generalized over.
[envGeneralizeMetas] :: TCEnv -> DoGeneralize

-- | Values for used generalizable variables.
[envGeneralizedVars] :: TCEnv -> Map QName GeneralizedValue

-- | Is some backend active at the moment, and if yes, which? NB: we only
--   store the <a>BackendName</a> here, otherwise <tt>instance Data
--   TCEnv</tt> is not derivable. The actual backend can be obtained from
--   the name via <a>stBackends</a>.
[envActiveBackendName] :: TCEnv -> Maybe BackendName

-- | Are we currently computing the overlap between two rewrite rules for
--   the purpose of confluence checking?
[envConflComputingOverlap] :: TCEnv -> Bool

-- | Are we currently in the process of executing an elaborate-and-give
--   interactive command?
[envCurrentlyElaborating] :: TCEnv -> Bool

-- | If this counter is <a>Nothing</a>, then syntactic equality checking is
--   unrestricted. If it is zero, then syntactic equality checking is not
--   run at all. If it is a positive number, then syntactic equality
--   checking is allowed to run, but the counter is decreased in the
--   failure continuation of <a>checkSyntacticEquality</a>.
[envSyntacticEqualityFuel] :: TCEnv -> !Maybe Int

-- | Unique identifier of the opaque block we are currently under, if any.
--   Used by the scope checker (to associate definitions to blocks), and by
--   the type checker (for unfolding control).
[envCurrentOpaqueId] :: TCEnv -> !Maybe OpaqueId
data Interface
Interface :: !Hash -> Text -> FileType -> [(TopLevelModuleName, Hash)] -> ModuleName -> TopLevelModuleName -> Map ModuleName Scope -> ScopeInfo -> Signature -> RemoteMetaStore -> DisplayForms -> Map QName Text -> Maybe Text -> BuiltinThings (PrimitiveId, QName) -> Map BackendName ForeignCodeStack -> HighlightingInfo -> [OptionsPragma] -> [OptionsPragma] -> PragmaOptions -> PatternSynDefns -> [TCWarning] -> Set QName -> Map OpaqueId OpaqueBlock -> Map QName OpaqueId -> Interface

-- | Hash of the source code.
[iSourceHash] :: Interface -> !Hash

-- | The source code. The source code is stored so that the HTML and LaTeX
--   backends can generate their output without having to re-read the
--   (possibly out of date) source code.
[iSource] :: Interface -> Text

-- | Source file type, determined from the file extension
[iFileType] :: Interface -> FileType

-- | Imported modules and their hashes.
[iImportedModules] :: Interface -> [(TopLevelModuleName, Hash)]

-- | Module name of this interface.
[iModuleName] :: Interface -> ModuleName

-- | The module's top-level module name.
[iTopLevelModuleName] :: Interface -> TopLevelModuleName

-- | Scope defined by this module.
--   
--   Andreas, AIM XX: Too avoid duplicate serialization, this field is not
--   serialized, so if you deserialize an interface, <tt>iScope</tt> will
--   be empty. But <tt>constructIScope</tt> constructs <a>iScope</a> from
--   <a>iInsideScope</a>.
[iScope] :: Interface -> Map ModuleName Scope

-- | Scope after we loaded this interface. Used in <a>AtTopLevel</a> and
--   <a>interactionLoop</a>.
[iInsideScope] :: Interface -> ScopeInfo
[iSignature] :: Interface -> Signature

-- | Instantiations for meta-variables that come from this module.
[iMetaBindings] :: Interface -> RemoteMetaStore

-- | Display forms added for imported identifiers.
[iDisplayForms] :: Interface -> DisplayForms

-- | User warnings for imported identifiers
[iUserWarnings] :: Interface -> Map QName Text

-- | Whether this module should raise a warning when imported
[iImportWarning] :: Interface -> Maybe Text
[iBuiltin] :: Interface -> BuiltinThings (PrimitiveId, QName)
[iForeignCode] :: Interface -> Map BackendName ForeignCodeStack
[iHighlighting] :: Interface -> HighlightingInfo

-- | Pragma options set in library files.
[iDefaultPragmaOptions] :: Interface -> [OptionsPragma]

-- | Pragma options set in the file.
[iFilePragmaOptions] :: Interface -> [OptionsPragma]

-- | Options/features used when checking the file (can be different from
--   options set directly in the file).
[iOptionsUsed] :: Interface -> PragmaOptions
[iPatternSyns] :: Interface -> PatternSynDefns
[iWarnings] :: Interface -> [TCWarning]
[iPartialDefs] :: Interface -> Set QName
[iOpaqueBlocks] :: Interface -> Map OpaqueId OpaqueBlock
[iOpaqueNames] :: Interface -> Map QName OpaqueId

-- | The constraints needed for <a>typeError</a> and similar.
type MonadTCError m = (MonadTCEnv m, ReadTCState m, MonadError TCErr m)
type BackendName = String
data TCState
TCSt :: !PreScopeState -> !PostScopeState -> !PersistentTCState -> TCState

-- | The state which is frozen after scope checking.
[stPreScopeState] :: TCState -> !PreScopeState

-- | The state which is modified after scope checking.
[stPostScopeState] :: TCState -> !PostScopeState

-- | State which is forever, like a diamond.
[stPersistentState] :: TCState -> !PersistentTCState
type RewriteRules = [RewriteRule]
data PrimFun
PrimFun :: QName -> Arity -> [Occurrence] -> ([Arg Term] -> Int -> ReduceM (Reduced MaybeReducedArgs Term)) -> PrimFun
[primFunName] :: PrimFun -> QName
[primFunArity] :: PrimFun -> Arity

-- | See <a>defArgOccurrences</a>.
[primFunArgOccurrences] :: PrimFun -> [Occurrence]
[primFunImplementation] :: PrimFun -> [Arg Term] -> Int -> ReduceM (Reduced MaybeReducedArgs Term)
data RunMetaOccursCheck
RunMetaOccursCheck :: RunMetaOccursCheck
DontRunMetaOccursCheck :: RunMetaOccursCheck

-- | We can either compare two terms at a given type, or compare two types
--   without knowing (or caring about) their sorts.
data CompareAs

-- | <tt>Type</tt> should not be <tt>Size</tt>. But currently, we do not
--   rely on this invariant.
AsTermsOf :: Type -> CompareAs

-- | Replaces <tt>AsTermsOf Size</tt>.
AsSizes :: CompareAs
AsTypes :: CompareAs

-- | An extension of <a>Comparison</a> to <tt>&gt;=</tt>.
data CompareDirection
DirEq :: CompareDirection
DirLeq :: CompareDirection
DirGeq :: CompareDirection

-- | Information about local meta-variables.
data MetaVariable
MetaVar :: MetaInfo -> MetaPriority -> Permutation -> Judgement MetaId -> MetaInstantiation -> Set Listener -> Frozen -> Maybe MetaId -> MetaVariable
[mvInfo] :: MetaVariable -> MetaInfo

-- | some metavariables are more eager to be instantiated
[mvPriority] :: MetaVariable -> MetaPriority

-- | a metavariable doesn't have to depend on all variables in the context,
--   this "permutation" will throw away the ones it does not depend on
[mvPermutation] :: MetaVariable -> Permutation
[mvJudgement] :: MetaVariable -> Judgement MetaId
[mvInstantiation] :: MetaVariable -> MetaInstantiation

-- | meta variables scheduled for eta-expansion but blocked by this one
[mvListeners] :: MetaVariable -> Set Listener

-- | are we past the point where we can instantiate this meta variable?
[mvFrozen] :: MetaVariable -> Frozen

-- | <tt>Just m</tt> means that this meta-variable will be equated to
--   <tt>m</tt> when the latter is unblocked. See
--   <a>blockTermOnProblem</a>.
[mvTwin] :: MetaVariable -> Maybe MetaId

-- | Information about an <tt>instance</tt> definition.
data InstanceInfo
InstanceInfo :: QName -> OverlapMode -> InstanceInfo

-- | Name of the "class" this is an instance for
[instanceClass] :: InstanceInfo -> QName

-- | Does this instance have a specified overlap mode?
[instanceOverlap] :: InstanceInfo -> OverlapMode
class Monad m => MonadBlock m

-- | `patternViolation b` aborts the current computation
patternViolation :: MonadBlock m => Blocker -> m a

-- | `patternViolation b` aborts the current computation
patternViolation :: (MonadBlock m, MonadTrans t, MonadBlock n, m ~ t n) => Blocker -> m a

-- | `catchPatternErr handle m` runs m, handling pattern violations with
--   <tt>handle</tt> (doesn't roll back the state)
catchPatternErr :: MonadBlock m => (Blocker -> m a) -> m a -> m a
data Reduced no yes
NoReduction :: no -> Reduced no yes
YesReduction :: Simplification -> yes -> Reduced no yes
data ProblemConstraint
PConstr :: Set ProblemId -> Blocker -> Closure Constraint -> ProblemConstraint
[constraintProblems] :: ProblemConstraint -> Set ProblemId
[constraintUnblocker] :: ProblemConstraint -> Blocker
[theConstraint] :: ProblemConstraint -> Closure Constraint
newtype Fields
Fields :: [(Name, Type)] -> Fields
data ForeignCode
ForeignCode :: Range -> String -> ForeignCode
data LetBinding
LetBinding :: Origin -> Term -> Dom Type -> LetBinding
[letOrigin] :: LetBinding -> Origin
[letTerm] :: LetBinding -> Term
[letType] :: LetBinding -> Dom Type
newtype Section
Section :: Telescope -> Section
[_secTelescope] :: Section -> Telescope
data PreScopeState
PreScopeState :: !HighlightingInfo -> !Signature -> !Set TopLevelModuleName -> !ModuleToSource -> !VisitedModules -> !ScopeInfo -> !PatternSynDefns -> !PatternSynDefns -> !Maybe (Set QName) -> !PragmaOptions -> !BuiltinThings PrimFun -> !DisplayForms -> !InteractionId -> !Map QName Text -> !Map QName Text -> !Maybe Text -> !Set QName -> !Map FilePath ProjectConfig -> !Map FilePath AgdaLibFile -> !RemoteMetaStore -> !HashMap QName QName -> !HashMap QName (HashSet QName) -> PreScopeState

-- | Highlighting info for tokens and Happy parser warnings (but not for
--   those tokens/warnings for which highlighting exists in
--   <a>stPostSyntaxInfo</a>).
[stPreTokens] :: PreScopeState -> !HighlightingInfo

-- | Imported declared identifiers. Those most not be serialized!
[stPreImports] :: PreScopeState -> !Signature

-- | The top-level modules imported by the current module.
[stPreImportedModules] :: PreScopeState -> !Set TopLevelModuleName
[stPreModuleToSource] :: PreScopeState -> !ModuleToSource
[stPreVisitedModules] :: PreScopeState -> !VisitedModules
[stPreScope] :: PreScopeState -> !ScopeInfo

-- | Pattern synonyms of the current file. Serialized.
[stPrePatternSyns] :: PreScopeState -> !PatternSynDefns

-- | Imported pattern synonyms. Must not be serialized!
[stPrePatternSynImports] :: PreScopeState -> !PatternSynDefns

-- | Collected generalizable variables; used during scope checking of terms
[stPreGeneralizedVars] :: PreScopeState -> !Maybe (Set QName)

-- | Options applying to the current file. <tt>OPTIONS</tt> pragmas only
--   affect this field.
[stPrePragmaOptions] :: PreScopeState -> !PragmaOptions
[stPreImportedBuiltins] :: PreScopeState -> !BuiltinThings PrimFun

-- | Display forms added by someone else to imported identifiers
[stPreImportedDisplayForms] :: PreScopeState -> !DisplayForms
[stPreFreshInteractionId] :: PreScopeState -> !InteractionId

-- | Imported <tt>UserWarning</tt>s, not to be stored in the
--   <tt>Interface</tt>
[stPreImportedUserWarnings] :: PreScopeState -> !Map QName Text

-- | Locally defined <tt>UserWarning</tt>s, to be stored in the
--   <tt>Interface</tt>
[stPreLocalUserWarnings] :: PreScopeState -> !Map QName Text

-- | Whether the current module should raise a warning when opened
[stPreWarningOnImport] :: PreScopeState -> !Maybe Text

-- | Imported partial definitions, not to be stored in the
--   <tt>Interface</tt>
[stPreImportedPartialDefs] :: PreScopeState -> !Set QName

-- | Map from directories to paths of closest enclosing .agda-lib files (or
--   <tt>Nothing</tt> if there are none).
[stPreProjectConfigs] :: PreScopeState -> !Map FilePath ProjectConfig

-- | Contents of .agda-lib files that have already been parsed.
[stPreAgdaLibFiles] :: PreScopeState -> !Map FilePath AgdaLibFile

-- | Used for meta-variables from other modules.
[stPreImportedMetaStore] :: PreScopeState -> !RemoteMetaStore

-- | Associates a copied name (the key) to its original name (the value).
--   Computed by the scope checker, used to compute opaque blocks.
[stPreCopiedNames] :: PreScopeState -> !HashMap QName QName

-- | Associates an original name (the key) to all its copies (the value).
--   Computed by the scope checker, used to compute opaque blocks.
[stPreNameCopies] :: PreScopeState -> !HashMap QName (HashSet QName)
data PostScopeState
PostScopeState :: !HighlightingInfo -> !DisambiguatedNames -> !LocalMetaStore -> !LocalMetaStore -> !InteractionPoints -> !Constraints -> !Constraints -> !Bool -> !Set QName -> !Signature -> !Map ModuleName CheckpointId -> !DisplayForms -> !Map BackendName ForeignCodeStack -> !Maybe (ModuleName, TopLevelModuleName) -> !Set QName -> !Set QName -> !ConcreteNames -> !Map RawName (DList RawName) -> !Map Name (DList RawName) -> !Statistics -> ![TCWarning] -> !Map MutualId MutualBlock -> !BuiltinThings PrimFun -> !MetaId -> !MutualId -> !ProblemId -> !CheckpointId -> !Int -> !NameId -> !OpaqueId -> !Bool -> !Bool -> !Bool -> !Bool -> !Set QName -> Map OpaqueId OpaqueBlock -> Map QName OpaqueId -> PostScopeState

-- | Highlighting info.
[stPostSyntaxInfo] :: PostScopeState -> !HighlightingInfo

-- | Disambiguation carried out by the type checker. Maps position of first
--   name character to disambiguated <tt><a>QName</a></tt> for each
--   <tt><a>AmbiguousQName</a></tt> already passed by the type checker.
[stPostDisambiguatedNames] :: PostScopeState -> !DisambiguatedNames

-- | Used for open meta-variables.
[stPostOpenMetaStore] :: PostScopeState -> !LocalMetaStore

-- | Used for local, instantiated meta-variables.
[stPostSolvedMetaStore] :: PostScopeState -> !LocalMetaStore
[stPostInteractionPoints] :: PostScopeState -> !InteractionPoints
[stPostAwakeConstraints] :: PostScopeState -> !Constraints
[stPostSleepingConstraints] :: PostScopeState -> !Constraints

-- | Dirty when a constraint is added, used to prevent pointer update.
--   Currently unused.
[stPostDirty] :: PostScopeState -> !Bool

-- | Definitions to be considered during occurs check. Initialized to the
--   current mutual block before the check. During occurs check, we remove
--   definitions from this set as soon we have checked them.
[stPostOccursCheckDefs] :: PostScopeState -> !Set QName

-- | Declared identifiers of the current file. These will be serialized
--   after successful type checking.
[stPostSignature] :: PostScopeState -> !Signature

-- | For each module remember the checkpoint corresponding to the orignal
--   context of the module parameters.
[stPostModuleCheckpoints] :: PostScopeState -> !Map ModuleName CheckpointId

-- | Display forms we add for imported identifiers
[stPostImportsDisplayForms] :: PostScopeState -> !DisplayForms

-- | <tt>{-# FOREIGN #-}</tt> code that should be included in the compiled
--   output. Does not include code for imported modules.
[stPostForeignCode] :: PostScopeState -> !Map BackendName ForeignCodeStack

-- | The current module is available after it has been type checked.
[stPostCurrentModule] :: PostScopeState -> !Maybe (ModuleName, TopLevelModuleName)
[stPostPendingInstances] :: PostScopeState -> !Set QName
[stPostTemporaryInstances] :: PostScopeState -> !Set QName

-- | Map keeping track of concrete names assigned to each abstract name
--   (can be more than one name in case the first one is shadowed)
[stPostConcreteNames] :: PostScopeState -> !ConcreteNames

-- | Map keeping track for each name root (= name w/o numeric suffixes)
--   what names with the same root have been used during a TC computation.
--   This information is used to build the <tt>ShadowingNames</tt> map.
[stPostUsedNames] :: PostScopeState -> !Map RawName (DList RawName)

-- | Map keeping track for each (abstract) name the list of all (raw) names
--   that it could maybe be shadowed by.
[stPostShadowingNames] :: PostScopeState -> !Map Name (DList RawName)

-- | Counters to collect various statistics about meta variables etc. Only
--   for current file.
[stPostStatistics] :: PostScopeState -> !Statistics
[stPostTCWarnings] :: PostScopeState -> ![TCWarning]
[stPostMutualBlocks] :: PostScopeState -> !Map MutualId MutualBlock
[stPostLocalBuiltins] :: PostScopeState -> !BuiltinThings PrimFun
[stPostFreshMetaId] :: PostScopeState -> !MetaId
[stPostFreshMutualId] :: PostScopeState -> !MutualId
[stPostFreshProblemId] :: PostScopeState -> !ProblemId
[stPostFreshCheckpointId] :: PostScopeState -> !CheckpointId
[stPostFreshInt] :: PostScopeState -> !Int
[stPostFreshNameId] :: PostScopeState -> !NameId
[stPostFreshOpaqueId] :: PostScopeState -> !OpaqueId
[stPostAreWeCaching] :: PostScopeState -> !Bool
[stPostPostponeInstanceSearch] :: PostScopeState -> !Bool
[stPostConsideringInstance] :: PostScopeState -> !Bool

-- | Should we instantiate away blocking metas? This can produce ill-typed
--   terms but they are often more readable. See issue #3606. Best set to
--   True only for calls to pretty*/reify to limit unwanted reductions.
[stPostInstantiateBlocking] :: PostScopeState -> !Bool

-- | Local partial definitions, to be stored in the <tt>Interface</tt>
[stPostLocalPartialDefs] :: PostScopeState -> !Set QName

-- | Associates opaque identifiers to their actual blocks.
[stPostOpaqueBlocks] :: PostScopeState -> Map OpaqueId OpaqueBlock

-- | Associates each opaque QName to the block it was defined in.
[stPostOpaqueIds] :: PostScopeState -> Map QName OpaqueId

-- | A part of the state which is not reverted when an error is thrown or
--   the state is reset.
data PersistentTCState
PersistentTCSt :: !DecodedModules -> !BiMap RawTopLevelModuleName ModuleNameHash -> CommandLineOptions -> InteractionOutputCallback -> !Benchmark -> !Statistics -> !Maybe LoadedFileCache -> [Backend_boot TCM] -> PersistentTCState
[stDecodedModules] :: PersistentTCState -> !DecodedModules

-- | Module name hashes for top-level module names (and vice versa).
[stPersistentTopLevelModuleNames] :: PersistentTCState -> !BiMap RawTopLevelModuleName ModuleNameHash
[stPersistentOptions] :: PersistentTCState -> CommandLineOptions

-- | Callback function to call when there is a response to give to the
--   interactive frontend. See the documentation of
--   <a>InteractionOutputCallback</a>.
[stInteractionOutputCallback] :: PersistentTCState -> InteractionOutputCallback

-- | Structure to track how much CPU time was spent on which Agda phase.
--   Needs to be a strict field to avoid space leaks!
[stBenchmark] :: PersistentTCState -> !Benchmark

-- | Should be strict field.
[stAccumStatistics] :: PersistentTCState -> !Statistics

-- | Cached typechecking state from the last loaded file. Should be
--   <tt>Nothing</tt> when checking imports.
[stPersistLoadedFileCache] :: PersistentTCState -> !Maybe LoadedFileCache

-- | Current backends with their options
[stPersistBackends] :: PersistentTCState -> [Backend_boot TCM]
type VisitedModules = Map TopLevelModuleName ModuleInfo
type BuiltinThings pf = Map SomeBuiltin (Builtin pf)
type DisplayForms = HashMap QName [LocalDisplayForm]

-- | Used for meta-variables from other modules (and in <a>Interface</a>s).
type RemoteMetaStore = HashMap MetaId RemoteMetaVariable

-- | Name disambiguation for the sake of highlighting.
data DisambiguatedName
DisambiguatedName :: NameKind -> QName -> DisambiguatedName
type DisambiguatedNames = IntMap DisambiguatedName
type ConcreteNames = Map Name [Name]

-- | Used for meta-variables from the current module.
type LocalMetaStore = Map MetaId MetaVariable

-- | Data structure managing the interaction points.
--   
--   We never remove interaction points from this map, only set their
--   <a>ipSolved</a> to <tt>True</tt>. (Issue #2368)
type InteractionPoints = BiMap InteractionId InteractionPoint
newtype CheckpointId
CheckpointId :: Int -> CheckpointId

-- | Foreign code fragments are stored in reversed order to support
--   efficient appending: head points to the latest pragma in module.
newtype ForeignCodeStack
ForeignCodeStack :: [ForeignCode] -> ForeignCodeStack
[getForeignCodeStack] :: ForeignCodeStack -> [ForeignCode]
newtype MutualId
MutId :: Int32 -> MutualId

-- | A mutual block of names in the signature.
data MutualBlock
MutualBlock :: MutualInfo -> Set QName -> MutualBlock

-- | The original info of the mutual block.
[mutualInfo] :: MutualBlock -> MutualInfo
[mutualNames] :: MutualBlock -> Set QName

-- | A block of opaque definitions.
data OpaqueBlock
OpaqueBlock :: {-# UNPACK #-} !OpaqueId -> HashSet QName -> HashSet QName -> Maybe OpaqueId -> Range -> OpaqueBlock

-- | Unique identifier for this block.
[opaqueId] :: OpaqueBlock -> {-# UNPACK #-} !OpaqueId

-- | Set of names we are allowed to unfold. After scope-checking, this set
--   should be transitively closed.
[opaqueUnfolding] :: OpaqueBlock -> HashSet QName

-- | Declarations contained in this abstract block.
[opaqueDecls] :: OpaqueBlock -> HashSet QName

-- | Pointer to an enclosing opaque block, if one exists.
[opaqueParent] :: OpaqueBlock -> Maybe OpaqueId

-- | Where is this opaque block?
[opaqueRange] :: OpaqueBlock -> Range
type DecodedModules = Map TopLevelModuleName ModuleInfo
data LoadedFileCache
LoadedFileCache :: !CachedTypeCheckLog -> !CurrentTypeCheckLog -> LoadedFileCache
[lfcCached] :: LoadedFileCache -> !CachedTypeCheckLog
[lfcCurrent] :: LoadedFileCache -> !CurrentTypeCheckLog

-- | A log of what the type checker does and states after the action is
--   completed. The cached version is stored first executed action first.
type CachedTypeCheckLog = [(TypeCheckAction, PostScopeState)]

-- | Like <a>CachedTypeCheckLog</a>, but storing the log for an ongoing
--   type checking of a module. Stored in reverse order (last performed
--   action first).
type CurrentTypeCheckLog = [(TypeCheckAction, PostScopeState)]

-- | A complete log for a module will look like this:
--   
--   <ul>
--   <li><a>Pragmas</a></li>
--   <li><a>EnterSection</a>, entering the main module.</li>
--   <li><a>Decl</a><i><a>EnterSection</a></i><a>LeaveSection</a>, for
--   declarations and nested modules</li>
--   <li><a>LeaveSection</a>, leaving the main module.</li>
--   </ul>
data TypeCheckAction
EnterSection :: !Erased -> !ModuleName -> !Telescope -> TypeCheckAction
LeaveSection :: !ModuleName -> TypeCheckAction

-- | Never a Section or ScopeDecl
Decl :: !Declaration -> TypeCheckAction
Pragmas :: !PragmaOptions -> TypeCheckAction

-- | When typechecking something of the following form:
--   
--   instance x : _ x = y
--   
--   it's not yet known where to add <tt>x</tt>, so we add it to a list of
--   unresolved instances and we'll deal with it later.
type TempInstanceTable = (InstanceTable, Set QName)
class Enum i => HasFresh i
freshLens :: HasFresh i => Lens' TCState i
nextFresh' :: HasFresh i => i -> i
class Monad m => MonadFresh i m
fresh :: MonadFresh i m => m i
fresh :: (MonadFresh i m, MonadTrans t, MonadFresh i n, t n ~ m) => m i

-- | Create a fresh name from <tt>a</tt>.
class FreshName a
freshName_ :: (FreshName a, MonadFresh NameId m) => a -> m Name

-- | A monad that has read and write access to the stConcreteNames part of
--   the TCState. Basically, this is a synonym for `MonadState
--   ConcreteNames m` (which cannot be used directly because of the
--   limitations of Haskell's typeclass system).
class Monad m => MonadStConcreteNames m
runStConcreteNames :: MonadStConcreteNames m => StateT ConcreteNames m a -> m a
useConcreteNames :: MonadStConcreteNames m => m ConcreteNames
modifyConcreteNames :: MonadStConcreteNames m => (ConcreteNames -> ConcreteNames) -> m ()

-- | Distinguishes between type-checked and scope-checked interfaces when
--   stored in the map of <a>VisitedModules</a>.
data ModuleCheckMode
ModuleScopeChecked :: ModuleCheckMode
ModuleTypeChecked :: ModuleCheckMode
class LensClosure b a | b -> a
lensClosure :: LensClosure b a => Lens' b (Closure a)
class LensTCEnv a
lensTCEnv :: LensTCEnv a => Lens' a TCEnv

-- | Why are we performing a modality check?
data WhyCheckModality

-- | Because --without-K is enabled, so the types of data constructors must
--   be usable at the context's modality.
ConstructorType :: WhyCheckModality

-- | Because --without-K is enabled, so the result type of clauses must be
--   usable at the context's modality.
IndexedClause :: WhyCheckModality

-- | Because --without-K is enabled, so any argument (second name) which
--   mentions a dotted argument (first name) must have a type which is
--   usable at the context's modality.
IndexedClauseArg :: Name -> Name -> WhyCheckModality

-- | Because we double-check the --cubical-compatible clauses. This is an
--   internal error!
GeneratedClause :: WhyCheckModality

-- | Information about whether an argument is forced by the type of a
--   function.
data IsForced
Forced :: IsForced
NotForced :: IsForced

-- | A candidate solution for an instance meta is a term with its type. It
--   may be the case that the candidate is not fully applied yet or of the
--   wrong type, hence the need for the type.
data Candidate
Candidate :: CandidateKind -> Term -> Type -> OverlapMode -> Candidate
[candidateKind] :: Candidate -> CandidateKind
[candidateTerm] :: Candidate -> Term
[candidateType] :: Candidate -> Type
[candidateOverlap] :: Candidate -> OverlapMode

-- | Parametrized since it is used without MetaId when creating a new meta.
data Judgement a
HasType :: a -> Comparison -> Type -> Judgement a
[jMetaId] :: Judgement a -> a

-- | are we checking (<tt>CmpLeq</tt>) or inferring (<tt>CmpEq</tt>) the
--   type?
[jComparison] :: Judgement a -> Comparison
[jMetaType] :: Judgement a -> Type
IsSort :: a -> Type -> Judgement a
[jMetaId] :: Judgement a -> a
[jMetaType] :: Judgement a -> Type
data DoGeneralize

-- | Generalize because it is a generalizable variable.
YesGeneralizeVar :: DoGeneralize

-- | Generalize because it is a metavariable and we're currently checking
--   the type of a generalizable variable (this should get the default
--   modality).
YesGeneralizeMeta :: DoGeneralize

-- | Don't generalize.
NoGeneralize :: DoGeneralize

-- | The value of a generalizable variable. This is created to be a
--   generalizable meta before checking the type to be generalized.
data GeneralizedValue
GeneralizedValue :: CheckpointId -> Term -> Type -> GeneralizedValue
[genvalCheckpoint] :: GeneralizedValue -> CheckpointId
[genvalTerm] :: GeneralizedValue -> Term
[genvalType] :: GeneralizedValue -> Type

-- | Meta variable priority: When we have an equation between
--   meta-variables, which one should be instantiated?
--   
--   Higher value means higher priority to be instantiated.
newtype MetaPriority
MetaPriority :: Int -> MetaPriority

-- | Solution status of meta.
data MetaInstantiation

-- | Solved by <a>Instantiation</a>.
InstV :: Instantiation -> MetaInstantiation

-- | Unsolved (open to solutions).
OpenMeta :: MetaKind -> MetaInstantiation

-- | Solved, but solution blocked by unsolved constraints.
BlockedConst :: Term -> MetaInstantiation

-- | Meta stands for value of the expression that is still to be type
--   checked.
PostponedTypeCheckingProblem :: Closure TypeCheckingProblem -> MetaInstantiation
data Listener
EtaExpand :: MetaId -> Listener
CheckConstraint :: Nat -> ProblemConstraint -> Listener

-- | Frozen meta variable cannot be instantiated by unification. This
--   serves to prevent the completion of a definition by its use outside of
--   the current block. (See issues 118, 288, 399).
data Frozen

-- | Do not instantiate.
Frozen :: Frozen
Instantiable :: Frozen

-- | Meta-variable instantiations.
data Instantiation
Instantiation :: [Arg String] -> Term -> Instantiation

-- | The solution is abstracted over these free variables.
[instTel] :: Instantiation -> [Arg String]

-- | The body of the solution.
[instBody] :: Instantiation -> Term
data TypeCheckingProblem
CheckExpr :: Comparison -> Expr -> Type -> TypeCheckingProblem
CheckArgs :: Comparison -> ExpandHidden -> Range -> [NamedArg Expr] -> Type -> Type -> (ArgsCheckState CheckedTarget -> TCM Term) -> TypeCheckingProblem
CheckProjAppToKnownPrincipalArg :: Comparison -> Expr -> ProjOrigin -> List1 QName -> Args -> Type -> Int -> Term -> Type -> PrincipalArgTypeMetas -> TypeCheckingProblem

-- | <tt>(λ (xs : t₀) → e) : t</tt> This is not an instance of
--   <a>CheckExpr</a> as the domain type has already been checked. For
--   example, when checking <tt>(λ (x y : Fin _) → e) : (x : Fin n) →
--   ?</tt> we want to postpone <tt>(λ (y : Fin n) → e) : ?</tt> where
--   <tt>Fin n</tt> is a <a>Type</a> rather than an <a>Expr</a>.
CheckLambda :: Comparison -> Arg (List1 (WithHiding Name), Maybe Type) -> Expr -> Type -> TypeCheckingProblem

-- | Quote the given term and check type against <a>Term</a>
DoQuoteTerm :: Comparison -> Term -> Type -> TypeCheckingProblem

-- | Information about remote meta-variables.
--   
--   Remote meta-variables are meta-variables originating in other modules.
--   These meta-variables are always instantiated. We do not retain all the
--   information about a local meta-variable when creating an interface:
--   
--   <ul>
--   <li>The <a>mvPriority</a> field is not needed, because the
--   meta-variable cannot be instantiated.</li>
--   <li>The <a>mvFrozen</a> field is not needed, because there is no point
--   in freezing instantiated meta-variables.</li>
--   <li>The <a>mvListeners</a> field is not needed, because no
--   meta-variable should be listening to this one.</li>
--   <li>The <a>mvTwin</a> field is not needed, because the meta-variable
--   has already been instantiated.</li>
--   <li>The <a>mvPermutation</a> is currently removed, but could be
--   retained if it turns out to be useful for something.</li>
--   <li>The only part of the <a>mvInfo</a> field that is kept is the
--   <a>miModality</a> field. The <a>miMetaOccursCheck</a> and
--   <a>miGeneralizable</a> fields are omitted, because the meta-variable
--   has already been instantiated. The <a>Range'</a> that is part of the
--   <a>miClosRange</a> field and the <a>miNameSuggestion</a> field are
--   omitted because instantiated meta-variables are typically not
--   presented to users. Finally the <a>Closure</a> part of the
--   <a>miClosRange</a> field is omitted because it can be large (at least
--   if we ignore potential sharing).</li>
--   </ul>
data RemoteMetaVariable
RemoteMetaVariable :: Instantiation -> Modality -> Judgement MetaId -> RemoteMetaVariable
[rmvInstantiation] :: RemoteMetaVariable -> Instantiation
[rmvModality] :: RemoteMetaVariable -> Modality
[rmvJudgement] :: RemoteMetaVariable -> Judgement MetaId

-- | Solving a <a>CheckArgs</a> constraint may or may not check the target
--   type. If it did, it returns a handle to any unsolved constraints.
data CheckedTarget
CheckedTarget :: Maybe ProblemId -> CheckedTarget
NotCheckedTarget :: CheckedTarget
data PrincipalArgTypeMetas
PrincipalArgTypeMetas :: Args -> Type -> PrincipalArgTypeMetas

-- | metas created for hidden and instance arguments in the principal
--   argument's type
[patmMetas] :: PrincipalArgTypeMetas -> Args

-- | principal argument's type, stripped of hidden and instance arguments
[patmRemainder] :: PrincipalArgTypeMetas -> Type
data ExpandHidden

-- | Add implicit arguments in the end until type is no longer hidden
--   <a>Pi</a>.
ExpandLast :: ExpandHidden

-- | Do not append implicit arguments.
DontExpandLast :: ExpandHidden

-- | Makes <tt>doExpandLast</tt> have no effect. Used to avoid implicit
--   insertion of arguments to metavariables.
ReallyDontExpandLast :: ExpandHidden
data ArgsCheckState a
ACState :: [Maybe Range] -> Elims -> [Maybe (Abs Constraint)] -> Type -> a -> ArgsCheckState a

-- | Ranges of checked arguments, where present. e.g. inserted implicits
--   have no correponding abstract syntax.
[acRanges] :: ArgsCheckState a -> [Maybe Range]

-- | Checked and inserted arguments so far.
[acElims] :: ArgsCheckState a -> Elims

-- | Constraints for the head so far, i.e. before applying the correponding
--   elim.
[acConstraints] :: ArgsCheckState a -> [Maybe (Abs Constraint)]

-- | Type for the rest of the application.
[acType] :: ArgsCheckState a -> Type
[acData] :: ArgsCheckState a -> a

-- | Interaction points are created by the scope checker who sets the
--   range. The meta variable is created by the type checker and then
--   hooked up to the interaction point.
data InteractionPoint
InteractionPoint :: Range -> Maybe MetaId -> Bool -> IPClause -> IPBoundary -> InteractionPoint

-- | The position of the interaction point.
[ipRange] :: InteractionPoint -> Range

-- | The meta variable, if any, holding the type etc.
[ipMeta] :: InteractionPoint -> Maybe MetaId

-- | Has this interaction point already been solved?
[ipSolved] :: InteractionPoint -> Bool

-- | The clause of the interaction point (if any). Used for case splitting.
[ipClause] :: InteractionPoint -> IPClause
[ipBoundary] :: InteractionPoint -> IPBoundary

-- | Which clause is an interaction point located in?
data IPClause
IPClause :: QName -> Int -> Type -> Maybe Substitution -> SpineClause -> Closure () -> IPClause

-- | The name of the function.
[ipcQName] :: IPClause -> QName

-- | The number of the clause of this function.
[ipcClauseNo] :: IPClause -> Int

-- | The type of the function
[ipcType] :: IPClause -> Type

-- | Module parameter substitution
[ipcWithSub] :: IPClause -> Maybe Substitution

-- | The original AST clause.
[ipcClause] :: IPClause -> SpineClause

-- | Environment for rechecking the clause.
[ipcClosure] :: IPClause -> Closure ()

-- | The interaction point is not in the rhs of a clause.
IPNoClause :: IPClause
type IPBoundary = IPBoundary' Term

-- | Flag to indicate whether the meta is overapplied in the constraint. A
--   meta is overapplied if it has more arguments than the size of the
--   telescope in its creation environment (as stored in MetaInfo).
data Overapplied
Overapplied :: Overapplied
NotOverapplied :: Overapplied
newtype IPBoundary' t
IPBoundary :: Map (IntMap Bool) t -> IPBoundary' t
[getBoundary] :: IPBoundary' t -> Map (IntMap Bool) t
type Sections = Map ModuleName Section
type RewriteRuleMap = HashMap QName RewriteRules

-- | Records information about the instances in the signature. Does not
--   deal with local instances.
data InstanceTable
InstanceTable :: DiscrimTree QName -> Map QName Int -> InstanceTable

-- | The actual discrimination tree for looking up instances with
[_itableTree] :: InstanceTable -> DiscrimTree QName

-- | For profiling, we store the number of instances on a per-class basis.
--   This lets us compare the result from the discrimination tree with all
--   the instances in scope, thus informing us how many validity checks
--   were skipped.
[_itableCounts] :: InstanceTable -> Map QName Int
type LocalDisplayForm = Open DisplayForm

-- | A structured presentation of a <a>Term</a> for reification into
--   <a>Syntax</a>.
data DisplayTerm

-- | <tt>(f vs | ws) es</tt>. The first <a>DisplayTerm</a> is the parent
--   function <tt>f</tt> with its args <tt>vs</tt>. The list of
--   <a>DisplayTerm</a>s are the with expressions <tt>ws</tt>. The
--   <a>Elims</a> are additional arguments <tt>es</tt> (possible in case
--   the with-application is of function type) or projections (if it is of
--   record type).
DWithApp :: DisplayTerm -> [DisplayTerm] -> Elims -> DisplayTerm

-- | <tt>c vs</tt>.
DCon :: ConHead -> ConInfo -> [Arg DisplayTerm] -> DisplayTerm

-- | <tt>d vs</tt>.
DDef :: QName -> [Elim' DisplayTerm] -> DisplayTerm

-- | <tt>.(v es)</tt>. See <a>DTerm'</a>.
DDot' :: Term -> Elims -> DisplayTerm

-- | <tt>v es</tt>. This is a frozen elimination that is not always safe to
--   run, because display forms may be ill-typed. (See issue #6476.)
DTerm' :: Term -> Elims -> DisplayTerm

-- | Non-linear (non-constructor) first-order pattern.
data NLPat

-- | Matches anything (modulo non-linearity) that only contains bound
--   variables that occur in the given arguments.
PVar :: !Int -> [Arg Int] -> NLPat

-- | Matches <tt>f es</tt>
PDef :: QName -> PElims -> NLPat

-- | Matches <tt>λ x → t</tt>
PLam :: ArgInfo -> Abs NLPat -> NLPat

-- | Matches <tt>(x : A) → B</tt>
PPi :: Dom NLPType -> Abs NLPType -> NLPat

-- | Matches a sort of the given shape.
PSort :: NLPSort -> NLPat

-- | Matches <tt>x es</tt> where x is a lambda-bound variable
PBoundVar :: {-# UNPACK #-} !Int -> PElims -> NLPat

-- | Matches the term modulo β (ideally βη).
PTerm :: Term -> NLPat
type PElims = [Elim' NLPat]
data NLPType
NLPType :: NLPSort -> NLPat -> NLPType
[nlpTypeSort] :: NLPType -> NLPSort
[nlpTypeUnEl] :: NLPType -> NLPat
data NLPSort
PUniv :: Univ -> NLPat -> NLPSort
PInf :: Univ -> Integer -> NLPSort
PSizeUniv :: NLPSort
PLockUniv :: NLPSort
PLevelUniv :: NLPSort
PIntervalUniv :: NLPSort

-- | Rewrite rules can be added independently from function clauses.
data RewriteRule
RewriteRule :: QName -> Telescope -> QName -> PElims -> Term -> Type -> Bool -> RewriteRule

-- | Name of rewrite rule <tt>q : Γ → f ps ≡ rhs</tt> where <tt>≡</tt> is
--   the rewrite relation.
[rewName] :: RewriteRule -> QName

-- | <tt>Γ</tt>.
[rewContext] :: RewriteRule -> Telescope

-- | <tt>f</tt>.
[rewHead] :: RewriteRule -> QName

-- | <tt>Γ ⊢ f ps : t</tt>.
[rewPats] :: RewriteRule -> PElims

-- | <tt>Γ ⊢ rhs : t</tt>.
[rewRHS] :: RewriteRule -> Term

-- | <tt>Γ ⊢ t</tt>.
[rewType] :: RewriteRule -> Type

-- | Was this rewrite rule created from a clause in the definition of the
--   function?
[rewFromClause] :: RewriteRule -> Bool
data Defn

-- | Postulate.
AxiomDefn :: AxiomData -> Defn

-- | Data or record type signature that doesn't yet have a definition.
DataOrRecSigDefn :: DataOrRecSigData -> Defn

-- | Generalizable variable (introduced in <tt>generalize</tt> block).
GeneralizableVar :: Defn

-- | Returned by <tt>getConstInfo</tt> if definition is abstract.
AbstractDefn :: Defn -> Defn
FunctionDefn :: FunctionData -> Defn
DatatypeDefn :: DatatypeData -> Defn
RecordDefn :: RecordData -> Defn
ConstructorDefn :: ConstructorData -> Defn

-- | Primitive or builtin functions.
PrimitiveDefn :: PrimitiveData -> Defn
PrimitiveSortDefn :: PrimitiveSortData -> Defn
data NumGeneralizableArgs
NoGeneralizableArgs :: NumGeneralizableArgs

-- | When lambda-lifting new args are generalizable if
--   <a>SomeGeneralizableArgs</a>, also when the number is zero.
SomeGeneralizableArgs :: !Int -> NumGeneralizableArgs
type CompiledRepresentation = Map BackendName [CompilerPragma]
type Face = [(Term, Bool)]

-- | Additional information for extended lambdas.
data ExtLamInfo
ExtLamInfo :: ModuleName -> Bool -> !Maybe System -> ExtLamInfo

-- | For complicated reasons the scope checker decides the QName of a
--   pattern lambda, and thus its module. We really need to decide the
--   module during type checking though, since if the lambda appears in a
--   refined context the module picked by the scope checker has very much
--   the wrong parameters.
[extLamModule] :: ExtLamInfo -> ModuleName

-- | Was this definition created from an absurd lambda <tt>λ ()</tt>?
[extLamAbsurd] :: ExtLamInfo -> Bool
[extLamSys] :: ExtLamInfo -> !Maybe System

-- | Additional information for projection <a>Function</a>s.
data Projection
Projection :: Maybe QName -> QName -> Arg QName -> Int -> ProjLams -> Projection

-- | <tt>Nothing</tt> if only projection-like, <tt>Just r</tt> if record
--   projection. The <tt>r</tt> is the name of the record type projected
--   from. This field is updated by module application.
[projProper] :: Projection -> Maybe QName

-- | The original projection name (current name could be from module
--   application).
[projOrig] :: Projection -> QName

-- | Type projected from. Original record type if <tt>projProper =
--   Just{}</tt>. Also stores <tt>ArgInfo</tt> of the principal argument.
--   This field is unchanged by module application.
[projFromType] :: Projection -> Arg QName

-- | Index of the record argument. Start counting with 1, because 0 means
--   that it is already applied to the record value. This can happen in
--   module instantiation, but then either the record value is <tt>var
--   0</tt>, or <tt>funProjection == Left _</tt>.
[projIndex] :: Projection -> Int

-- | Term <tt>t</tt> to be be applied to record parameters and record
--   value. The parameters will be dropped. In case of a proper projection,
--   a postfix projection application will be created: <tt>t = pars r -&gt;
--   r .p</tt> (Invariant: the number of abstractions equals
--   <a>projIndex</a>.) In case of a projection-like function, just the
--   function symbol is returned as <a>Def</a>: <tt>t = pars -&gt; f</tt>.
[projLams] :: Projection -> ProjLams

-- | Abstractions to build projection function (dropping parameters).
newtype ProjLams
ProjLams :: [Arg ArgName] -> ProjLams
[getProjLams] :: ProjLams -> [Arg ArgName]

-- | Should a record type admit eta-equality?
data EtaEquality

-- | User specifed 'eta-equality' or 'no-eta-equality'.
Specified :: !HasEta -> EtaEquality
[theEtaEquality] :: EtaEquality -> !HasEta

-- | Positivity checker inferred whether eta is safe.
Inferred :: !HasEta -> EtaEquality
[theEtaEquality] :: EtaEquality -> !HasEta
data FunctionFlag

-- | Should calls to this function be normalised at compile-time?
FunStatic :: FunctionFlag

-- | Should calls to this function be inlined by the compiler?
FunInline :: FunctionFlag

-- | Is this function a macro?
FunMacro :: FunctionFlag

-- | Is this function <tt>INJECTIVE_FOR_INFERENCE</tt>? Indicates whether
--   the first-order shortcut should be applied to the definition.
FunFirstOrder :: FunctionFlag

-- | Was <tt>--erasure</tt> in effect when the function was defined? (This
--   can affect the type of a projection.)
FunErasure :: FunctionFlag

-- | Is the function abstract?
FunAbstract :: FunctionFlag

-- | Is this function a descendant of a field (typically, a projection)?
FunProj :: FunctionFlag
data CompKit
CompKit :: Maybe QName -> Maybe QName -> CompKit
[nameOfHComp] :: CompKit -> Maybe QName
[nameOfTransp] :: CompKit -> Maybe QName
data AxiomData
AxiomData :: Bool -> AxiomData

-- | Can transp for this postulate be constant? Set to <tt>True</tt> for
--   bultins like String.
[_axiomConstTransp] :: AxiomData -> Bool
data DataOrRecSigData
DataOrRecSigData :: Int -> DataOrRecSigData
[_datarecPars] :: DataOrRecSigData -> Int
data FunctionData
FunctionData :: [Clause] -> Maybe CompiledClauses -> Maybe SplitTree -> Maybe Compiled -> [Clause] -> FunctionInverse -> Maybe [QName] -> Either ProjectionLikenessMissing Projection -> SmallSet FunctionFlag -> Maybe Bool -> Maybe ExtLamInfo -> Maybe QName -> Maybe QName -> IsOpaque -> FunctionData
[_funClauses] :: FunctionData -> [Clause]

-- | <a>Nothing</a> while function is still type-checked. <tt>Just cc</tt>
--   after type and coverage checking and translation to case trees.
[_funCompiled] :: FunctionData -> Maybe CompiledClauses

-- | The split tree constructed by the coverage checker. Needed to
--   re-compile the clauses after forcing translation.
[_funSplitTree] :: FunctionData -> Maybe SplitTree

-- | Intermediate representation for compiler backends.
[_funTreeless] :: FunctionData -> Maybe Compiled

-- | Covering clauses computed by coverage checking. Erased by (IApply)
--   confluence checking(?)
[_funCovering] :: FunctionData -> [Clause]
[_funInv] :: FunctionData -> FunctionInverse

-- | Mutually recursive functions, <tt>data</tt>s and <tt>record</tt>s.
--   Does include this function. Empty list if not recursive.
--   <tt>Nothing</tt> if not yet computed (by positivity checker).
[_funMutual] :: FunctionData -> Maybe [QName]

-- | Is it a record projection? If yes, then return the name of the record
--   type and index of the record argument. Start counting with 1, because
--   0 means that it is already applied to the record. (Can happen in
--   module instantiation.) This information is used in the termination
--   checker.
[_funProjection] :: FunctionData -> Either ProjectionLikenessMissing Projection

-- | Various boolean flags pertaining to the function definition, see
--   <a>FunctionFlag</a>.
[_funFlags] :: FunctionData -> SmallSet FunctionFlag

-- | Has this function been termination checked? Did it pass?
[_funTerminates] :: FunctionData -> Maybe Bool

-- | Is this function generated from an extended lambda? If yes, then
--   return the number of hidden and non-hidden lambda-lifted arguments.
[_funExtLam] :: FunctionData -> Maybe ExtLamInfo

-- | Is this a generated with-function? If yes, then what's the name of the
--   parent function?
[_funWith] :: FunctionData -> Maybe QName

-- | Is this a helper for one of the Kan operations (transp, hcomp) on data
--   types/records? If so, for which data type?
[_funIsKanOp] :: FunctionData -> Maybe QName

-- | Is this function opaque? If so, and we're not in an opaque block that
--   includes this function('s name), it will be treated abstractly.
[_funOpaque] :: FunctionData -> IsOpaque
data DatatypeData
DatatypeData :: Nat -> Nat -> Maybe Clause -> [QName] -> Sort -> Maybe [QName] -> IsAbstract -> [QName] -> Maybe QName -> Maybe QName -> DatatypeData

-- | Number of parameters.
[_dataPars] :: DatatypeData -> Nat

-- | Number of indices.
[_dataIxs] :: DatatypeData -> Nat

-- | This might be in an instantiated module.
[_dataClause] :: DatatypeData -> Maybe Clause

-- | Constructor names, ordered according to the order of their definition.
[_dataCons] :: DatatypeData -> [QName]
[_dataSort] :: DatatypeData -> Sort

-- | Mutually recursive functions, <tt>data</tt>s and <tt>record</tt>s.
--   Does include this data type. Empty if not recursive. <tt>Nothing</tt>
--   if not yet computed (by positivity checker).
[_dataMutual] :: DatatypeData -> Maybe [QName]
[_dataAbstr] :: DatatypeData -> IsAbstract

-- | Path constructor names (subset of <tt>dataCons</tt>).
[_dataPathCons] :: DatatypeData -> [QName]

-- | If indexed datatype, name of the "index transport" function.
[_dataTranspIx] :: DatatypeData -> Maybe QName

-- | Transport function, should be available for all datatypes in supported
--   sorts.
[_dataTransp] :: DatatypeData -> Maybe QName
data RecordData
RecordData :: Nat -> Maybe Clause -> ConHead -> Bool -> [Dom QName] -> Telescope -> Maybe [QName] -> EtaEquality -> PatternOrCopattern -> Maybe Induction -> Maybe Bool -> IsAbstract -> CompKit -> RecordData

-- | Number of parameters.
[_recPars] :: RecordData -> Nat

-- | Was this record type created by a module application? If yes, the
--   clause is its definition (linking back to the original record type).
[_recClause] :: RecordData -> Maybe Clause

-- | Constructor name and fields.
[_recConHead] :: RecordData -> ConHead

-- | Does this record have a <tt>constructor</tt>?
[_recNamedCon] :: RecordData -> Bool

-- | The record field names.
[_recFields] :: RecordData -> [Dom QName]

-- | The record field telescope. (Includes record parameters.) Note:
--   <tt>TelV recTel _ == telView' recConType</tt>. Thus, <tt>recTel</tt>
--   is redundant.
[_recTel] :: RecordData -> Telescope

-- | Mutually recursive functions, <tt>data</tt>s and <tt>record</tt>s.
--   Does include this record. Empty if not recursive. <tt>Nothing</tt> if
--   not yet computed (by positivity checker).
[_recMutual] :: RecordData -> Maybe [QName]

-- | Eta-expand at this record type? <tt>False</tt> for unguarded recursive
--   records and coinductive records unless the user specifies otherwise.
[_recEtaEquality'] :: RecordData -> EtaEquality

-- | In case eta-equality is off, do we allow pattern matching on the
--   constructor or construction by copattern matching? Having both loses
--   subject reduction, see issue #4560. After positivity checking, this
--   field is obsolete, part of <a>EtaEquality</a>.
[_recPatternMatching] :: RecordData -> PatternOrCopattern

-- | <a>Inductive</a> or <a>CoInductive</a>? Matters only for recursive
--   records. <a>Nothing</a> means that the user did not specify it, which
--   is an error for recursive records.
[_recInduction] :: RecordData -> Maybe Induction

-- | 'Just True' means that unfolding of the recursive record terminates,
--   'Just False' means that we have no evidence for termination, and
--   <a>Nothing</a> means we have not run the termination checker yet.
[_recTerminates] :: RecordData -> Maybe Bool
[_recAbstr] :: RecordData -> IsAbstract
[_recComp] :: RecordData -> CompKit
data ConstructorData
ConstructorData :: Int -> Int -> ConHead -> QName -> IsAbstract -> CompKit -> Maybe [QName] -> [IsForced] -> Maybe [Bool] -> !Bool -> !Bool -> ConstructorData

-- | Number of parameters.
[_conPars] :: ConstructorData -> Int

-- | Number of arguments (excluding parameters).
[_conArity] :: ConstructorData -> Int

-- | Name of (original) constructor and fields. (This might be in a module
--   instance.)
[_conSrcCon] :: ConstructorData -> ConHead

-- | Name of datatype or record type.
[_conData] :: ConstructorData -> QName
[_conAbstr] :: ConstructorData -> IsAbstract

-- | Cubical composition.
[_conComp] :: ConstructorData -> CompKit

-- | Projections. <a>Nothing</a> if not yet computed.
[_conProj] :: ConstructorData -> Maybe [QName]

-- | Which arguments are forced (i.e. determined by the type of the
--   constructor)? Either this list is empty (if the forcing analysis isn't
--   run), or its length is <tt>conArity</tt>.
[_conForced] :: ConstructorData -> [IsForced]

-- | Which arguments are erased at runtime (computed during compilation to
--   treeless)? <a>True</a> means erased, <a>False</a> means retained.
--   <a>Nothing</a> if no erasure analysis has been performed yet. The
--   length of the list is <tt>conArity</tt>.
[_conErased] :: ConstructorData -> Maybe [Bool]

-- | Was <tt>--erasure</tt> in effect when the constructor was defined?
--   (This can affect the constructor's type.)
[_conErasure] :: ConstructorData -> !Bool

-- | Shall we translate the constructor on the root of the rhs into
--   copattern matching on the lhs? Activated by INLINE pragma.
[_conInline] :: ConstructorData -> !Bool
data PrimitiveData
PrimitiveData :: IsAbstract -> PrimitiveId -> [Clause] -> FunctionInverse -> Maybe CompiledClauses -> IsOpaque -> PrimitiveData
[_primAbstr] :: PrimitiveData -> IsAbstract
[_primName] :: PrimitiveData -> PrimitiveId

-- | <a>null</a> for primitive functions, <tt>not null</tt> for builtin
--   functions.
[_primClauses] :: PrimitiveData -> [Clause]

-- | Builtin functions can have inverses. For instance, natural number
--   addition.
[_primInv] :: PrimitiveData -> FunctionInverse

-- | <a>Nothing</a> for primitive functions, <tt><a>Just</a> something</tt>
--   for builtin functions.
[_primCompiled] :: PrimitiveData -> Maybe CompiledClauses

-- | Primitives can also live in opaque blocks.
[_primOpaque] :: PrimitiveData -> IsOpaque
data PrimitiveSortData
PrimitiveSortData :: BuiltinSort -> Sort -> PrimitiveSortData
[_primSortName] :: PrimitiveSortData -> BuiltinSort
[_primSortSort] :: PrimitiveSortData -> Sort

-- | Indicates the reason behind a function having not been marked
--   projection-like.
data ProjectionLikenessMissing

-- | Projection-likeness analysis has not run on this function yet. It may
--   do so in the future.
MaybeProjection :: ProjectionLikenessMissing

-- | The user has requested that this function be not be marked
--   projection-like. The analysis may already have run on this function,
--   but the results have been discarded, and it will not be run again.
NeverProjection :: ProjectionLikenessMissing
type FunctionInverse = FunctionInverse' Clause
data BuiltinSort
SortUniv :: Univ -> BuiltinSort
SortOmega :: Univ -> BuiltinSort
SortIntervalUniv :: BuiltinSort
SortLevelUniv :: BuiltinSort
data FunctionInverse' c
NotInjective :: FunctionInverse' c
Inverse :: InversionMap c -> FunctionInverse' c

-- | Did we encounter a simplifying reduction? In terms of CIC, that would
--   be a iota-reduction. In terms of Agda, this is a constructor or
--   literal pattern that matched. Just beta-reduction (substitution) or
--   delta-reduction (unfolding of definitions) does not count as
--   simplifying?
data Simplification
YesSimplification :: Simplification
NoSimplification :: Simplification

-- | Three cases: 1. not reduced, 2. reduced, but blocked, 3. reduced, not
--   blocked.
data IsReduced
NotReduced :: IsReduced
Reduced :: Blocked () -> IsReduced
data MaybeReduced a
MaybeRed :: IsReduced -> a -> MaybeReduced a
[isReduced] :: MaybeReduced a -> IsReduced
[ignoreReduced] :: MaybeReduced a -> a
type MaybeReducedArgs = [MaybeReduced (Arg Term)]
type MaybeReducedElims = [MaybeReduced Elim]

-- | Controlling <tt>reduce</tt>.
data AllowedReduction

-- | (Projection and) projection-like functions may be reduced.
ProjectionReductions :: AllowedReduction

-- | Functions marked INLINE may be reduced.
InlineReductions :: AllowedReduction

-- | Copattern definitions may be reduced.
CopatternReductions :: AllowedReduction

-- | Non-recursive functions and primitives may be reduced.
FunctionReductions :: AllowedReduction

-- | Even recursive functions may be reduced.
RecursiveReductions :: AllowedReduction

-- | Reduce <tt><a>Term</a></tt> terms.
LevelReductions :: AllowedReduction

-- | Allow <tt>allReductions</tt> in types, even if not allowed at term
--   level (used by confluence checker)
TypeLevelReductions :: AllowedReduction

-- | Functions whose termination has not (yet) been confirmed.
UnconfirmedReductions :: AllowedReduction

-- | Functions that have failed termination checking.
NonTerminatingReductions :: AllowedReduction
type AllowedReductions = SmallSet AllowedReduction
data ReduceDefs
OnlyReduceDefs :: Set QName -> ReduceDefs
DontReduceDefs :: Set QName -> ReduceDefs

-- | Primitives
data PrimitiveImpl
PrimImpl :: Type -> PrimFun -> PrimitiveImpl
type InversionMap c = Map TermHead [c]
data TermHead
SortHead :: TermHead
PiHead :: TermHead
ConsHead :: QName -> TermHead
VarHead :: Nat -> TermHead
UnknownHead :: TermHead
data BuiltinDescriptor
BuiltinData :: TCM Type -> [BuiltinId] -> BuiltinDescriptor
BuiltinDataCons :: TCM Type -> BuiltinDescriptor
BuiltinPrim :: PrimitiveId -> (Term -> TCM ()) -> BuiltinDescriptor
BuiltinSort :: BuiltinSort -> BuiltinDescriptor
BuiltinPostulate :: Relevance -> TCM Type -> BuiltinDescriptor

-- | Builtin of any kind. Type can be checked (<tt>Just t</tt>) or inferred
--   (<tt>Nothing</tt>). The second argument is the hook for the
--   verification function.
BuiltinUnknown :: Maybe (TCM Type) -> (Term -> Type -> TCM ()) -> BuiltinDescriptor
data BuiltinInfo
BuiltinInfo :: BuiltinId -> BuiltinDescriptor -> BuiltinInfo
[builtinName] :: BuiltinInfo -> BuiltinId
[builtinDesc] :: BuiltinInfo -> BuiltinDescriptor
type LetBindings = Map Name (Open LetBinding)
data AbstractMode

-- | Abstract things in the current module can be accessed.
AbstractMode :: AbstractMode

-- | No abstract things can be accessed.
ConcreteMode :: AbstractMode

-- | All abstract things can be accessed.
IgnoreAbstractMode :: AbstractMode
data UnquoteFlags
UnquoteFlags :: Bool -> UnquoteFlags
[_unquoteNormalise] :: UnquoteFlags -> Bool
data CandidateKind
LocalCandidate :: CandidateKind
GlobalCandidate :: QName -> CandidateKind

-- | Information about a mutual block which did not pass the termination
--   checker.
data TerminationError
TerminationError :: [QName] -> [CallInfo] -> TerminationError

-- | The functions which failed to check. (May not include automatically
--   generated functions.)
[termErrFunctions] :: TerminationError -> [QName]

-- | The problematic call sites.
[termErrCalls] :: TerminationError -> [CallInfo]
data IllegalRewriteRuleReason
LHSNotDefinitionOrConstructor :: IllegalRewriteRuleReason
VariablesNotBoundByLHS :: IntSet -> IllegalRewriteRuleReason
VariablesBoundMoreThanOnce :: IntSet -> IllegalRewriteRuleReason
LHSReduces :: Term -> Term -> IllegalRewriteRuleReason
HeadSymbolIsProjection :: QName -> IllegalRewriteRuleReason
HeadSymbolIsProjectionLikeFunction :: QName -> IllegalRewriteRuleReason
HeadSymbolIsTypeConstructor :: QName -> IllegalRewriteRuleReason
HeadSymbolContainsMetas :: QName -> IllegalRewriteRuleReason
ConstructorParametersNotGeneral :: ConHead -> Args -> IllegalRewriteRuleReason
ContainsUnsolvedMetaVariables :: Set MetaId -> IllegalRewriteRuleReason
BlockedOnProblems :: Set ProblemId -> IllegalRewriteRuleReason
RequiresDefinitions :: Set QName -> IllegalRewriteRuleReason
DoesNotTargetRewriteRelation :: IllegalRewriteRuleReason
BeforeFunctionDefinition :: IllegalRewriteRuleReason
BeforeMutualFunctionDefinition :: QName -> IllegalRewriteRuleReason
DuplicateRewriteRule :: IllegalRewriteRuleReason

-- | Information about a call.
data CallInfo
CallInfo :: QName -> Closure Term -> CallInfo

-- | Target function name. (Contains its range.)
[callInfoTarget] :: CallInfo -> QName

-- | To be formatted representation of the call.
[callInfoCall] :: CallInfo -> Closure Term

-- | The reason for an <a>ErasedDatatype</a> error.
data ErasedDatatypeReason

-- | There are several constructors.
SeveralConstructors :: ErasedDatatypeReason

-- | The flag <tt>--erased-matches</tt> is not used.
NoErasedMatches :: ErasedDatatypeReason

-- | The K rule is not activated.
NoK :: ErasedDatatypeReason

-- | Error when splitting a pattern variable into possible constructor
--   patterns.
data SplitError

-- | Neither data type nor record.
NotADatatype :: Closure Type -> SplitError

-- | Type could not be sufficiently reduced.
BlockedType :: Blocker -> Closure Type -> SplitError

-- | Data type, but in erased position.
ErasedDatatype :: ErasedDatatypeReason -> Closure Type -> SplitError

-- | Split on codata not allowed. UNUSED, but keep! -- |
--   NoRecordConstructor Type -- ^ record type, but no constructor
CoinductiveDatatype :: Closure Type -> SplitError
UnificationStuck :: Maybe Blocker -> QName -> Telescope -> Args -> Args -> [UnificationFailure] -> SplitError

-- | Blocking metavariable (if any)
[cantSplitBlocker] :: SplitError -> Maybe Blocker

-- | Constructor.
[cantSplitConName] :: SplitError -> QName

-- | Context for indices.
[cantSplitTel] :: SplitError -> Telescope

-- | Inferred indices (from type of constructor).
[cantSplitConIdx] :: SplitError -> Args

-- | Expected indices (from checking pattern).
[cantSplitGivenIdx] :: SplitError -> Args

-- | Reason(s) why unification got stuck.
[cantSplitFailures] :: SplitError -> [UnificationFailure]

-- | Copattern split with a catchall
CosplitCatchall :: SplitError

-- | We do not know the target type of the clause.
CosplitNoTarget :: SplitError

-- | Target type is not a record type.
CosplitNoRecordType :: Closure Type -> SplitError
CannotCreateMissingClause :: QName -> (Telescope, [NamedArg DeBruijnPattern]) -> Doc -> Closure (Abs Type) -> SplitError
GenericSplitError :: String -> SplitError
data UnificationFailure

-- | Failed to apply injectivity to constructor of indexed datatype
UnifyIndicesNotVars :: Telescope -> Type -> Term -> Term -> Args -> UnificationFailure

-- | Can't solve equation because variable occurs in (type of) lhs
UnifyRecursiveEq :: Telescope -> Type -> Int -> Term -> UnificationFailure

-- | Can't solve reflexive equation because --without-K is enabled
UnifyReflexiveEq :: Telescope -> Type -> Term -> UnificationFailure

-- | Can't solve equation because solution modality is less "usable"
UnifyUnusableModality :: Telescope -> Type -> Int -> Term -> Modality -> UnificationFailure
data NegativeUnification
UnifyConflict :: Telescope -> Term -> Term -> NegativeUnification
UnifyCycle :: Telescope -> Int -> Term -> NegativeUnification
data UnquoteError
BadVisibility :: String -> Arg Term -> UnquoteError
ConInsteadOfDef :: QName -> String -> String -> UnquoteError
DefInsteadOfCon :: QName -> String -> String -> UnquoteError
NonCanonical :: String -> Term -> UnquoteError
BlockedOnMeta :: TCState -> Blocker -> UnquoteError
PatLamWithoutClauses :: Term -> UnquoteError
UnquotePanic :: String -> UnquoteError
type DataOrRecordE = DataOrRecord' InductionAndEta
data IncorrectTypeForRewriteRelationReason
ShouldAcceptAtLeastTwoArguments :: IncorrectTypeForRewriteRelationReason
FinalTwoArgumentsNotVisible :: IncorrectTypeForRewriteRelationReason
TypeDoesNotEndInSort :: Type -> Telescope -> IncorrectTypeForRewriteRelationReason

-- | Extra information for <a>InvalidFileName</a> error.
data InvalidFileNameReason
DoesNotCorrespondToValidModuleName :: InvalidFileNameReason
RootNameModuleNotAQualifiedModuleName :: Text -> InvalidFileNameReason
data InductionAndEta
InductionAndEta :: Maybe Induction -> EtaEquality -> InductionAndEta
[recordInduction] :: InductionAndEta -> Maybe Induction
[recordEtaEquality] :: InductionAndEta -> EtaEquality

-- | Environment of the reduce monad.
data ReduceEnv
ReduceEnv :: TCEnv -> TCState -> Maybe (MetaId -> ReduceM Bool) -> ReduceEnv

-- | Read only access to environment.
[redEnv] :: ReduceEnv -> TCEnv

-- | Read only access to state (signature, metas...).
[redSt] :: ReduceEnv -> TCState

-- | An optional predicate that is used by <tt>instantiate'</tt> and
--   <tt>instantiateFull'</tt>: meta-variables are only instantiated if
--   they satisfy this predicate.
[redPred] :: ReduceEnv -> Maybe (MetaId -> ReduceM Bool)
newtype BlockT m a
BlockT :: ExceptT Blocker m a -> BlockT m a
[unBlockT] :: BlockT m a -> ExceptT Blocker m a
pattern Function :: [Clause] -> Maybe CompiledClauses -> Maybe SplitTree -> Maybe Compiled -> [Clause] -> FunctionInverse -> Maybe [QName] -> Either ProjectionLikenessMissing Projection -> SmallSet FunctionFlag -> Maybe Bool -> Maybe ExtLamInfo -> Maybe QName -> Maybe QName -> IsOpaque -> Defn
pattern Constructor :: Int -> Int -> ConHead -> QName -> IsAbstract -> CompKit -> Maybe [QName] -> [IsForced] -> Maybe [Bool] -> Bool -> Bool -> Defn
pattern Datatype :: Nat -> Nat -> Maybe Clause -> [QName] -> Sort -> Maybe [QName] -> IsAbstract -> [QName] -> Maybe QName -> Maybe QName -> Defn
pattern Primitive :: IsAbstract -> PrimitiveId -> [Clause] -> FunctionInverse -> Maybe CompiledClauses -> IsOpaque -> Defn
pattern Record :: Nat -> Maybe Clause -> ConHead -> Bool -> [Dom QName] -> Telescope -> Maybe [QName] -> EtaEquality -> PatternOrCopattern -> Maybe Induction -> Maybe Bool -> IsAbstract -> CompKit -> Defn
pattern Axiom :: Bool -> Defn
pattern DDot :: Term -> DisplayTerm
pattern DTerm :: Term -> DisplayTerm
pattern PType :: NLPat -> NLPSort
pattern PProp :: NLPat -> NLPSort
pattern PSSet :: NLPat -> NLPSort
pattern DataOrRecSig :: Int -> Defn
pattern PrimitiveSort :: BuiltinSort -> Sort -> Defn
pattern SortProp :: BuiltinSort
pattern SortSet :: BuiltinSort
pattern SortStrictSet :: BuiltinSort
pattern SortPropOmega :: BuiltinSort
pattern SortSetOmega :: BuiltinSort
pattern SortStrictSetOmega :: BuiltinSort
typeError :: (HasCallStack, MonadTCError m) => TypeError -> m a
internalError :: (HasCallStack, MonadTCM tcm) => String -> tcm a
runReduceM :: ReduceM a -> TCM a
initState :: TCState

-- | The default <a>InteractionOutputCallback</a> function prints certain
--   things to stdout (other things generate internal errors).
defaultInteractionOutputCallback :: InteractionOutputCallback
mapTCMT :: (forall a. m a -> n a) -> TCMT m a -> TCMT n a
askR :: ReduceM ReduceEnv
defAbstract :: Definition -> IsAbstract
genericError :: (HasCallStack, MonadTCError m) => String -> m a
stModuleToSource :: Lens' TCState ModuleToSource
useTC :: ReadTCState m => Lens' TCState a -> m a
defOpaque :: Definition -> IsOpaque

-- | Empty persistent state.
initPersistentState :: PersistentTCState

-- | An initial <a>MetaId</a>.
initialMetaId :: MetaId

-- | Empty state of type checker.
initPreScopeState :: PreScopeState
emptySignature :: Signature
initPostScopeState :: PostScopeState
stTokens :: Lens' TCState HighlightingInfo
stImports :: Lens' TCState Signature
stImportedModules :: Lens' TCState (Set TopLevelModuleName)
stVisitedModules :: Lens' TCState VisitedModules
stScope :: Lens' TCState ScopeInfo
stPatternSyns :: Lens' TCState PatternSynDefns
stPatternSynImports :: Lens' TCState PatternSynDefns
stGeneralizedVars :: Lens' TCState (Maybe (Set QName))
stPragmaOptions :: Lens' TCState PragmaOptions
stImportedBuiltins :: Lens' TCState (BuiltinThings PrimFun)
stForeignCode :: Lens' TCState (Map BackendName ForeignCodeStack)
stFreshInteractionId :: Lens' TCState InteractionId
stImportedUserWarnings :: Lens' TCState (Map QName Text)
stLocalUserWarnings :: Lens' TCState (Map QName Text)
getUserWarnings :: ReadTCState m => m (Map QName Text)
useR :: ReadTCState m => Lens' TCState a -> m a
stWarningOnImport :: Lens' TCState (Maybe Text)
stImportedPartialDefs :: Lens' TCState (Set QName)
stLocalPartialDefs :: Lens' TCState (Set QName)
getPartialDefs :: ReadTCState m => m (Set QName)
stLoadedFileCache :: Lens' TCState (Maybe LoadedFileCache)
stBackends :: Lens' TCState [Backend_boot TCM]
stProjectConfigs :: Lens' TCState (Map FilePath ProjectConfig)
stAgdaLibFiles :: Lens' TCState (Map FilePath AgdaLibFile)
stTopLevelModuleNames :: Lens' TCState (BiMap RawTopLevelModuleName ModuleNameHash)
stImportedMetaStore :: Lens' TCState RemoteMetaStore
stCopiedNames :: Lens' TCState (HashMap QName QName)
stNameCopies :: Lens' TCState (HashMap QName (HashSet QName))
stFreshNameId :: Lens' TCState NameId
stFreshOpaqueId :: Lens' TCState OpaqueId
stOpaqueBlocks :: Lens' TCState (Map OpaqueId OpaqueBlock)
stOpaqueIds :: Lens' TCState (Map QName OpaqueId)
stSyntaxInfo :: Lens' TCState HighlightingInfo
stDisambiguatedNames :: Lens' TCState DisambiguatedNames
stOpenMetaStore :: Lens' TCState LocalMetaStore
stSolvedMetaStore :: Lens' TCState LocalMetaStore
stInteractionPoints :: Lens' TCState InteractionPoints
stAwakeConstraints :: Lens' TCState Constraints
stSleepingConstraints :: Lens' TCState Constraints
stDirty :: Lens' TCState Bool
stOccursCheckDefs :: Lens' TCState (Set QName)
stSignature :: Lens' TCState Signature
stModuleCheckpoints :: Lens' TCState (Map ModuleName CheckpointId)
stImportsDisplayForms :: Lens' TCState DisplayForms
stImportedDisplayForms :: Lens' TCState DisplayForms

-- | Note that the lens is "strict".
stCurrentModule :: Lens' TCState (Maybe (ModuleName, TopLevelModuleName))
stInstanceDefs :: Lens' TCState TempInstanceTable
sigInstances :: Lens' Signature InstanceTable
stTemporaryInstances :: Lens' TCState (Set QName)
stInstanceTree :: Lens' TCState (DiscrimTree QName)
itableTree :: Lens' InstanceTable (DiscrimTree QName)
stConcreteNames :: Lens' TCState ConcreteNames
stUsedNames :: Lens' TCState (Map RawName (DList RawName))
stShadowingNames :: Lens' TCState (Map Name (DList RawName))
stStatistics :: Lens' TCState Statistics
stTCWarnings :: Lens' TCState [TCWarning]
stMutualBlocks :: Lens' TCState (Map MutualId MutualBlock)
stLocalBuiltins :: Lens' TCState (BuiltinThings PrimFun)
stFreshMetaId :: Lens' TCState MetaId
stFreshMutualId :: Lens' TCState MutualId
stFreshProblemId :: Lens' TCState ProblemId
stFreshCheckpointId :: Lens' TCState CheckpointId
stFreshInt :: Lens' TCState Int
stAreWeCaching :: Lens' TCState Bool
stPostponeInstanceSearch :: Lens' TCState Bool
stConsideringInstance :: Lens' TCState Bool
stInstantiateBlocking :: Lens' TCState Bool
stBuiltinThings :: TCState -> BuiltinThings PrimFun

-- | Union two <a>Builtin</a>s. Only defined for
--   <a>BuiltinRewriteRelations</a>.
unionBuiltin :: Builtin a -> Builtin a -> Builtin a
nextFresh :: HasFresh i => TCState -> (i, TCState)
freshName :: MonadFresh NameId m => Range -> String -> m Name
freshNoName :: MonadFresh NameId m => Range -> m Name
freshNoName_ :: MonadFresh NameId m => m Name
freshRecordName :: MonadFresh NameId m => m Name

-- | Modify a part of the state monadically, and return some result.
stateTCLensM :: MonadTCState m => Lens' TCState a -> (a -> m (r, a)) -> m r

-- | Combines the source hash and the (full) hashes of the imported
--   modules.
iFullHash :: Interface -> Hash

-- | A lens for the <a>iSignature</a> field of the <a>Interface</a> type.
intSignature :: Lens' Interface Signature
buildClosure :: (MonadTCEnv m, ReadTCState m) => a -> m (Closure a)

-- | Embed <a>Comparison</a> into <a>CompareDirection</a>.
fromCmp :: Comparison -> CompareDirection

-- | Flip the direction of comparison.
flipCmp :: CompareDirection -> CompareDirection

-- | Turn a <a>Comparison</a> function into a <a>CompareDirection</a>
--   function.
--   
--   Property: <tt>dirToCmp f (fromCmp cmp) = f cmp</tt>
dirToCmp :: (Comparison -> a -> a -> c) -> CompareDirection -> a -> a -> c

-- | Append an <a>ArgName</a> to a <a>MetaNameSuggestion</a>, for computing
--   the name suggestions of eta-expansion metas. If the
--   <a>MetaNameSuggestion</a> is empty or an underscore, the field name is
--   taken as the suggestion.
suffixNameSuggestion :: MetaNameSuggestion -> ArgName -> MetaNameSuggestion
getMetaInfo :: MetaVariable -> Closure Range
normalMetaPriority :: MetaPriority
lowMetaPriority :: MetaPriority
highMetaPriority :: MetaPriority
getMetaScope :: MetaVariable -> ScopeInfo
getMetaEnv :: MetaVariable -> TCEnv
getMetaSig :: MetaVariable -> Signature
metaFrozen :: Lens' MetaVariable Frozen
_mvInfo :: Lens' MetaVariable MetaInfo
aModeToDef :: AbstractMode -> Maybe IsAbstract
aDefToMode :: IsAbstract -> AbstractMode
sigSections :: Lens' Signature Sections
sigDefinitions :: Lens' Signature Definitions
sigRewriteRules :: Lens' Signature RewriteRuleMap
secTelescope :: Lens' Section Telescope

-- | By default, we have no display form.
defaultDisplayForm :: QName -> [LocalDisplayForm]
lensTheDef :: Lens' Definition Defn

-- | Create a definition with sensible defaults.
defaultDefn :: ArgInfo -> QName -> Type -> Language -> Defn -> Definition
noCompiledRep :: CompiledRepresentation
jsBackendName :: BackendName
ghcBackendName :: BackendName
modifySystem :: (System -> System) -> ExtLamInfo -> ExtLamInfo

-- | Building the projection function (which drops the parameters).
projDropPars :: Projection -> ProjOrigin -> Term

-- | The info of the principal (record) argument.
projArgInfo :: Projection -> ArgInfo

-- | Make sure we do not overwrite a user specification.
setEtaEquality :: EtaEquality -> HasEta -> EtaEquality
emptyCompKit :: CompKit
defaultAxiom :: Defn
constTranspAxiom :: Defn
axiomConstTransp :: Defn -> Bool
datarecPars :: Defn -> Int
funClauses :: Defn -> [Clause]
funCompiled :: Defn -> Maybe CompiledClauses
funSplitTree :: Defn -> Maybe SplitTree
funTreeless :: Defn -> Maybe Compiled
funCovering :: Defn -> [Clause]
funInv :: Defn -> FunctionInverse
funMutual :: Defn -> Maybe [QName]
funProjection :: Defn -> Either ProjectionLikenessMissing Projection
funFlags :: Defn -> SmallSet FunctionFlag
funTerminates :: Defn -> Maybe Bool
funExtLam :: Defn -> Maybe ExtLamInfo
funWith :: Defn -> Maybe QName
funIsKanOp :: Defn -> Maybe QName
funOpaque :: Defn -> IsOpaque
dataPars :: Defn -> Nat
dataIxs :: Defn -> Nat
dataClause :: Defn -> Maybe Clause
dataCons :: Defn -> [QName]
dataSort :: Defn -> Sort
dataMutual :: Defn -> Maybe [QName]
dataAbstr :: Defn -> IsAbstract
dataPathCons :: Defn -> [QName]
dataTranspIx :: Defn -> Maybe QName
dataTransp :: Defn -> Maybe QName
recPars :: Defn -> Nat
recClause :: Defn -> Maybe Clause
recConHead :: Defn -> ConHead
recNamedCon :: Defn -> Bool
recFields :: Defn -> [Dom QName]
recTel :: Defn -> Telescope
recMutual :: Defn -> Maybe [QName]
recEtaEquality' :: Defn -> EtaEquality
recPatternMatching :: Defn -> PatternOrCopattern
recInduction :: Defn -> Maybe Induction
recTerminates :: Defn -> Maybe Bool
recAbstr :: Defn -> IsAbstract
recComp :: Defn -> CompKit
conPars :: Defn -> Int
conArity :: Defn -> Int
conSrcCon :: Defn -> ConHead
conData :: Defn -> QName
conAbstr :: Defn -> IsAbstract
conComp :: Defn -> CompKit
conProj :: Defn -> Maybe [QName]
conForced :: Defn -> [IsForced]
conErased :: Defn -> Maybe [Bool]
conErasure :: Defn -> Bool
conInline :: Defn -> Bool
primAbstr :: Defn -> IsAbstract
primName :: Defn -> PrimitiveId
primClauses :: Defn -> [Clause]
primInv :: Defn -> FunctionInverse
primCompiled :: Defn -> Maybe CompiledClauses
primOpaque :: Defn -> IsOpaque
primSortName :: Defn -> BuiltinSort
primSortSort :: Defn -> Sort
lensFunction :: Lens' Defn FunctionData
lensConstructor :: Lens' Defn ConstructorData
lensRecord :: Lens' Defn RecordData
lensRecTel :: Lens' RecordData Telescope
lensRecEta :: Lens' RecordData EtaEquality

-- | Is the record type recursive?
recRecursive :: Defn -> Bool
recRecursive_ :: RecordData -> Bool
recEtaEquality :: Defn -> HasEta
_recEtaEquality :: RecordData -> HasEta

-- | A template for creating <a>Function</a> definitions, with sensible
--   defaults.
emptyFunctionData :: HasOptions m => m FunctionData
emptyFunctionData_ :: Bool -> FunctionData
emptyFunction :: HasOptions m => m Defn
emptyFunction_ :: Bool -> Defn
funFlag_ :: FunctionFlag -> Lens' FunctionData Bool
funFlag :: FunctionFlag -> Lens' Defn Bool
funStatic :: Lens' Defn Bool
funInline :: Lens' Defn Bool
funMacro :: Lens' Defn Bool
funMacro_ :: Lens' FunctionData Bool

-- | Toggle the <a>FunFirstOrder</a> flag.
funFirstOrder :: Lens' Defn Bool

-- | Toggle the <a>FunErasure</a> flag.
funErasure :: Lens' Defn Bool

-- | Toggle the <a>FunAbstract</a> flag.
funAbstract :: Lens' Defn Bool

-- | Toggle the <a>FunAbstract</a> flag.
funAbstr :: Lens' Defn IsAbstract

-- | Toggle the <a>FunAbstract</a> flag.
funAbstract_ :: Lens' FunctionData Bool

-- | Toggle the <a>FunAbstract</a> flag.
funAbstr_ :: Lens' FunctionData IsAbstract

-- | Toggle the <a>FunProj</a> flag.
funProj :: Lens' Defn Bool

-- | Toggle the <a>FunProj</a> flag.
funProj_ :: Lens' FunctionData Bool
isMacro :: Defn -> Bool

-- | Checking whether we are dealing with a function yet to be defined.
isEmptyFunction :: Defn -> Bool
isCopatternLHS :: [Clause] -> Bool
recCon :: Defn -> QName
defIsRecord :: Defn -> Bool
defIsDataOrRecord :: Defn -> Bool
defConstructors :: Defn -> [QName]
redReturn :: a -> ReduceM (Reduced a' a)

-- | Conceptually: <tt>redBind m f k = either (return . Left . f) k
--   =&lt;&lt; m</tt>
redBind :: ReduceM (Reduced a a') -> (a -> b) -> (a' -> ReduceM (Reduced b b')) -> ReduceM (Reduced b b')
notReduced :: a -> MaybeReduced a
reduced :: Blocked (Arg Term) -> MaybeReduced (Arg Term)

-- | Not quite all reductions (skip non-terminating reductions)
allReductions :: AllowedReductions
reallyAllReductions :: AllowedReductions
reduceAllDefs :: ReduceDefs
locallyReduceDefs :: MonadTCEnv m => ReduceDefs -> m a -> m a

-- | Modify the lens-indicated part of the <tt>TCEnv</tt> in a
--   subcomputation.
locallyTC :: MonadTCEnv m => Lens' TCEnv a -> (a -> a) -> m b -> m b
eReduceDefs :: Lens' TCEnv ReduceDefs
locallyReduceAllDefs :: MonadTCEnv m => m a -> m a
shouldReduceDef :: MonadTCEnv m => QName -> m Bool
asksTC :: MonadTCEnv m => (TCEnv -> a) -> m a
toReduceDefs :: (Bool, [QName]) -> ReduceDefs
fromReduceDefs :: ReduceDefs -> (Bool, [QName])
locallyReconstructed :: MonadTCEnv m => m a -> m a
eReconstructed :: Lens' TCEnv Bool
isReconstructed :: MonadTCEnv m => m Bool
primFun :: QName -> Arity -> ([Arg Term] -> ReduceM (Reduced MaybeReducedArgs Term)) -> PrimFun
defClauses :: Definition -> [Clause]
defCompiled :: Definition -> Maybe CompiledClauses
defParameters :: Definition -> Maybe Nat
defInverse :: Definition -> FunctionInverse
defCompilerPragmas :: BackendName -> Definition -> [CompilerPragma]

-- | Has the definition failed the termination checker?
defNonterminating :: Definition -> Bool

-- | Has the definition not termination checked or did the check fail?
defTerminationUnconfirmed :: Definition -> Bool
defForced :: Definition -> [IsForced]
itableCounts :: Lens' InstanceTable (Map QName Int)

-- | <tt>ifTopLevelAndHighlightingLevelIs l b m</tt> runs <tt>m</tt> when
--   we're type-checking the top-level module (or before we've started
--   doing this) and either the highlighting level is <i>at least</i>
--   <tt>l</tt> or <tt>b</tt> is <a>True</a>.
ifTopLevelAndHighlightingLevelIsOr :: MonadTCEnv tcm => HighlightingLevel -> Bool -> tcm () -> tcm ()

-- | <tt>ifTopLevelAndHighlightingLevelIs l m</tt> runs <tt>m</tt> when
--   we're type-checking the top-level module (or before we've started
--   doing this) and the highlighting level is <i>at least</i> <tt>l</tt>.
ifTopLevelAndHighlightingLevelIs :: MonadTCEnv tcm => HighlightingLevel -> tcm () -> tcm ()
initEnv :: TCEnv
defaultUnquoteFlags :: UnquoteFlags
unquoteNormalise :: Lens' UnquoteFlags Bool
eUnquoteNormalise :: Lens' TCEnv Bool
eUnquoteFlags :: Lens' TCEnv UnquoteFlags
eContext :: Lens' TCEnv Context
eLetBindings :: Lens' TCEnv LetBindings
eCurrentModule :: Lens' TCEnv ModuleName
eCurrentPath :: Lens' TCEnv (Maybe AbsolutePath)
eAnonymousModules :: Lens' TCEnv [(ModuleName, Nat)]
eImportPath :: Lens' TCEnv [TopLevelModuleName]
eMutualBlock :: Lens' TCEnv (Maybe MutualId)
eTerminationCheck :: Lens' TCEnv (TerminationCheck ())
eCoverageCheck :: Lens' TCEnv CoverageCheck
eMakeCase :: Lens' TCEnv Bool
eSolvingConstraints :: Lens' TCEnv Bool
eCheckingWhere :: Lens' TCEnv Bool
eWorkingOnTypes :: Lens' TCEnv Bool
eAssignMetas :: Lens' TCEnv Bool
eActiveProblems :: Lens' TCEnv (Set ProblemId)
eAbstractMode :: Lens' TCEnv AbstractMode
eRelevance :: Lens' TCEnv Relevance

-- | Note that this lens does not satisfy all lens laws: If hard
--   compile-time mode is enabled, then quantities other than zero are
--   replaced by <a>__IMPOSSIBLE__</a>.
eQuantity :: Lens' TCEnv Quantity
eHardCompileTimeMode :: Lens' TCEnv Bool
eSplitOnStrict :: Lens' TCEnv Bool
eDisplayFormsEnabled :: Lens' TCEnv Bool
eFoldLetBindings :: Lens' TCEnv Bool
eRange :: Lens' TCEnv Range
eHighlightingRange :: Lens' TCEnv Range
eCall :: Lens' TCEnv (Maybe (Closure Call))
eHighlightingLevel :: Lens' TCEnv HighlightingLevel
eHighlightingMethod :: Lens' TCEnv HighlightingMethod
eExpandLast :: Lens' TCEnv ExpandHidden
eExpandLastBool :: Lens' TCEnv Bool
isExpandLast :: ExpandHidden -> Bool
toExpandLast :: Bool -> ExpandHidden
eAppDef :: Lens' TCEnv (Maybe QName)
eSimplification :: Lens' TCEnv Simplification
eAllowedReductions :: Lens' TCEnv AllowedReductions
eReduceDefsPair :: Lens' TCEnv (Bool, [QName])
eInjectivityDepth :: Lens' TCEnv Int
eCompareBlocked :: Lens' TCEnv Bool
ePrintDomainFreePi :: Lens' TCEnv Bool
ePrintMetasBare :: Lens' TCEnv Bool
eInsideDotPattern :: Lens' TCEnv Bool
eInstanceDepth :: Lens' TCEnv Int
eIsDebugPrinting :: Lens' TCEnv Bool
ePrintingPatternLambdas :: Lens' TCEnv [QName]
eCallByNeed :: Lens' TCEnv Bool
eCurrentCheckpoint :: Lens' TCEnv CheckpointId
eCheckpoints :: Lens' TCEnv (Map CheckpointId Substitution)
eGeneralizeMetas :: Lens' TCEnv DoGeneralize
eGeneralizedVars :: Lens' TCEnv (Map QName GeneralizedValue)
eActiveBackendName :: Lens' TCEnv (Maybe BackendName)
eConflComputingOverlap :: Lens' TCEnv Bool
eCurrentlyElaborating :: Lens' TCEnv Bool

-- | The current modality. Note that the returned cohesion component is
--   always <a>unitCohesion</a>.
currentModality :: MonadTCEnv m => m Modality
viewTC :: MonadTCEnv m => Lens' TCEnv a -> m a
onLetBindingType :: (Dom Type -> Dom Type) -> LetBinding -> LetBinding
isDontExpandLast :: ExpandHidden -> Bool
recordFieldWarningToError :: RecordFieldWarning -> TypeError
warningName :: Warning -> WarningName
illegalRewriteWarningName :: IllegalRewriteRuleReason -> WarningName

-- | Should warnings of that type be serialized?
--   
--   Only when changes in the source code can silence or influence the
--   warning.
isSourceCodeWarning :: WarningName -> Bool
tcWarningOrigin :: TCWarning -> SrcFile
sizedTypesOption :: HasOptions m => m Bool
guardednessOption :: HasOptions m => m Bool
withoutKOption :: HasOptions m => m Bool
cubicalOption :: HasOptions m => m (Maybe Cubical)
cubicalCompatibleOption :: HasOptions m => m Bool
enableCaching :: HasOptions m => m Bool
mapRedEnv :: (TCEnv -> TCEnv) -> ReduceEnv -> ReduceEnv
mapRedSt :: (TCState -> TCState) -> ReduceEnv -> ReduceEnv
mapRedEnvSt :: (TCEnv -> TCEnv) -> (TCState -> TCState) -> ReduceEnv -> ReduceEnv
reduceEnv :: Lens' ReduceEnv TCEnv
reduceSt :: Lens' ReduceEnv TCState
unKleisli :: (a -> ReduceM b) -> ReduceM (a -> b)
onReduceEnv :: (ReduceEnv -> ReduceEnv) -> ReduceM a -> ReduceM a
fmapReduce :: (a -> b) -> ReduceM a -> ReduceM b
apReduce :: ReduceM (a -> b) -> ReduceM a -> ReduceM b
thenReduce :: ReduceM a -> ReduceM b -> ReduceM b
beforeReduce :: ReduceM a -> ReduceM b -> ReduceM a
bindReduce :: ReduceM a -> (a -> ReduceM b) -> ReduceM b
runReduceF :: (a -> ReduceM b) -> TCM (a -> b)
localR :: (ReduceEnv -> ReduceEnv) -> ReduceM a -> ReduceM a
getsTC :: ReadTCState m => (TCState -> a) -> m a

-- | A variant of <a>modifyTC</a> in which the computation is strict in the
--   new state.
modifyTC' :: MonadTCState m => (TCState -> TCState) -> m ()

-- | Overwrite the part of the <a>TCState</a> focused on by the lens.
setTCLens :: MonadTCState m => Lens' TCState a -> a -> m ()
infix 4 `setTCLens`

-- | Overwrite the part of the <a>TCState</a> focused on by the lens
--   (strictly).
setTCLens' :: MonadTCState m => Lens' TCState a -> a -> m ()

-- | Modify the part of the <a>TCState</a> focused on by the lens.
modifyTCLens :: MonadTCState m => Lens' TCState a -> (a -> a) -> m ()

-- | Modify the part of the <a>TCState</a> focused on by the lens
--   (strictly).
modifyTCLens' :: MonadTCState m => Lens' TCState a -> (a -> a) -> m ()

-- | Modify a part of the state monadically.
modifyTCLensM :: MonadTCState m => Lens' TCState a -> (a -> m a) -> m ()

-- | Modify the part of the <a>TCState</a> focused on by the lens, and
--   return some result.
stateTCLens :: MonadTCState m => Lens' TCState a -> (a -> (r, a)) -> m r
runBlocked :: Monad m => BlockT m a -> m (Either Blocker a)
pureTCM :: MonadIO m => (TCState -> TCEnv -> a) -> TCMT m a
returnTCMT :: Applicative m => a -> TCMT m a
bindTCMT :: Monad m => TCMT m a -> (a -> TCMT m b) -> TCMT m b
thenTCMT :: Applicative m => TCMT m a -> TCMT m b -> TCMT m b
fmapTCMT :: Functor m => (a -> b) -> TCMT m a -> TCMT m b
apTCMT :: Applicative m => TCMT m (a -> b) -> TCMT m a -> TCMT m b

-- | Preserve the state of the failing computation.
catchError_ :: TCM a -> (TCErr -> TCM a) -> TCM a

-- | Execute a finalizer even when an exception is thrown. Does not catch
--   any errors. In case both the regular computation and the finalizer
--   throw an exception, the one of the finalizer is propagated.
finally_ :: TCM a -> TCM b -> TCM a
typeError' :: MonadTCError m => CallStack -> TypeError -> m a

-- | Utility function for 1-arg constructed type errors. Note that the
--   <tt>HasCallStack</tt> constraint is on the *resulting* function.
locatedTypeError :: MonadTCError m => (a -> TypeError) -> HasCallStack => a -> m b
genericDocError :: (HasCallStack, MonadTCError m) => Doc -> m a
typeError'_ :: (MonadTCEnv m, ReadTCState m) => CallStack -> TypeError -> m TCErr
typeError_ :: (HasCallStack, MonadTCEnv m, ReadTCState m) => TypeError -> m TCErr

-- | Running the type checking monad (most general form).
runTCM :: MonadIO m => TCEnv -> TCState -> TCMT m a -> m (a, TCState)

-- | Running the type checking monad on toplevel (with initial state).
runTCMTop :: TCM a -> IO (Either TCErr a)
runTCMTop' :: MonadIO m => TCMT m a -> m a

-- | <a>runSafeTCM</a> runs a safe <a>TCMT</a> action (a <a>TCMT</a> action
--   which cannot fail, except that it might raise <a>IOException</a>s) in
--   the initial environment.
runSafeTCM :: TCM a -> TCState -> IO (a, TCState)

-- | Runs the given computation in a separate thread, with <i>a copy</i> of
--   the current state and environment.
--   
--   Note that Agda sometimes uses actual, mutable state. If the
--   computation given to <tt>forkTCM</tt> tries to <i>modify</i> this
--   state, then bad things can happen, because accesses are not mutually
--   exclusive. The <tt>forkTCM</tt> function has been added mainly to
--   allow the thread to <i>read</i> (a snapshot of) the current state in a
--   convenient way.
--   
--   Note also that exceptions which are raised in the thread are not
--   propagated to the parent, so the thread should not do anything
--   important.
forkTCM :: TCM a -> TCM ()

-- | Base name for patterns in telescopes
patternInTeleName :: String

-- | Base name for extended lambda patterns
extendedLambdaName :: String

-- | Check whether we have an definition from an extended lambda.
isExtendedLambdaName :: QName -> Bool

-- | Name of absurdLambda definitions.
absurdLambdaName :: String

-- | Check whether we have an definition from an absurd lambda.
isAbsurdLambdaName :: QName -> Bool

-- | Base name for generalized variable projections
generalizedFieldName :: String

-- | Check whether we have a generalized variable field
getGeneralizedFieldName :: QName -> Maybe String
class (Functor m, Applicative m, Monad m) => HasOptions m

-- | Returns the pragma options which are currently in effect.
pragmaOptions :: HasOptions m => m PragmaOptions

-- | Returns the command line options which are currently in effect.
commandLineOptions :: HasOptions m => m CommandLineOptions

-- | Returns the pragma options which are currently in effect.
pragmaOptions :: (HasOptions m, HasOptions n, MonadTrans t, m ~ t n) => m PragmaOptions

-- | Returns the command line options which are currently in effect.
commandLineOptions :: (HasOptions m, HasOptions n, MonadTrans t, m ~ t n) => m CommandLineOptions
data RecordFieldWarning
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.DisambiguatedName
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.MutualBlock
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.MutualBlock
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.MutualBlock
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.TypeCheckAction
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.CheckpointId
instance GHC.Num.Num Agda.TypeChecking.Monad.Base.CheckpointId
instance GHC.Real.Integral Agda.TypeChecking.Monad.Base.CheckpointId
instance GHC.Real.Real Agda.TypeChecking.Monad.Base.CheckpointId
instance GHC.Enum.Enum Agda.TypeChecking.Monad.Base.CheckpointId
instance GHC.Classes.Ord Agda.TypeChecking.Monad.Base.CheckpointId
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.CheckpointId
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.ModuleCheckMode
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.ModuleCheckMode
instance GHC.Enum.Enum Agda.TypeChecking.Monad.Base.ModuleCheckMode
instance GHC.Enum.Bounded Agda.TypeChecking.Monad.Base.ModuleCheckMode
instance GHC.Classes.Ord Agda.TypeChecking.Monad.Base.ModuleCheckMode
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.ModuleCheckMode
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.ForeignCode
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.ForeignCode
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.ForeignCodeStack
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.ForeignCodeStack
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.ForeignCodeStack
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.WhyCheckModality
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.WhyCheckModality
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.Comparison
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.Comparison
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.Comparison
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.CompareDirection
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.CompareDirection
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.CompareAs
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.CompareAs
instance GHC.Generics.Generic (Agda.TypeChecking.Monad.Base.Open a)
instance Data.Traversable.Traversable Agda.TypeChecking.Monad.Base.Open
instance Data.Foldable.Foldable Agda.TypeChecking.Monad.Base.Open
instance GHC.Base.Functor Agda.TypeChecking.Monad.Base.Open
instance GHC.Show.Show a => GHC.Show.Show (Agda.TypeChecking.Monad.Base.Open a)
instance GHC.Generics.Generic (Agda.TypeChecking.Monad.Base.Judgement a)
instance GHC.Show.Show a => GHC.Show.Show (Agda.TypeChecking.Monad.Base.Judgement a)
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.DoGeneralize
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.DoGeneralize
instance GHC.Classes.Ord Agda.TypeChecking.Monad.Base.DoGeneralize
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.DoGeneralize
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.GeneralizedValue
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.GeneralizedValue
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.Frozen
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.Frozen
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.Frozen
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.Instantiation
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.Instantiation
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.RemoteMetaVariable
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.RemoteMetaVariable
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.PrincipalArgTypeMetas
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.MetaPriority
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.MetaPriority
instance GHC.Classes.Ord Agda.TypeChecking.Monad.Base.MetaPriority
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.MetaPriority
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.RunMetaOccursCheck
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.RunMetaOccursCheck
instance GHC.Classes.Ord Agda.TypeChecking.Monad.Base.RunMetaOccursCheck
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.RunMetaOccursCheck
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.Overapplied
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.Overapplied
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.Overapplied
instance GHC.Generics.Generic (Agda.TypeChecking.Monad.Base.IPBoundary' t)
instance Data.Traversable.Traversable Agda.TypeChecking.Monad.Base.IPBoundary'
instance Data.Foldable.Foldable Agda.TypeChecking.Monad.Base.IPBoundary'
instance GHC.Base.Functor Agda.TypeChecking.Monad.Base.IPBoundary'
instance GHC.Show.Show t => GHC.Show.Show (Agda.TypeChecking.Monad.Base.IPBoundary' t)
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Section
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.Section
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.DisplayTerm
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.DisplayTerm
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.DisplayForm
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.DisplayForm
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.NLPType
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.NLPType
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.NLPat
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.NLPat
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.NLPSort
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.NLPSort
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.RewriteRule
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.RewriteRule
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.InstanceInfo
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.InstanceInfo
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.NumGeneralizableArgs
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.Polarity
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.Polarity
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.Polarity
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.IsForced
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.IsForced
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.IsForced
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.CompilerPragma
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.CompilerPragma
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.CompilerPragma
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.System
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.System
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.ExtLamInfo
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.ExtLamInfo
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.ProjLams
instance Agda.Utils.Null.Null Agda.TypeChecking.Monad.Base.ProjLams
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.ProjLams
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.Projection
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.Projection
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.EtaEquality
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.EtaEquality
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.EtaEquality
instance GHC.Enum.Bounded Agda.TypeChecking.Monad.Base.FunctionFlag
instance GHC.Ix.Ix Agda.TypeChecking.Monad.Base.FunctionFlag
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.FunctionFlag
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.FunctionFlag
instance GHC.Enum.Enum Agda.TypeChecking.Monad.Base.FunctionFlag
instance GHC.Classes.Ord Agda.TypeChecking.Monad.Base.FunctionFlag
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.FunctionFlag
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.CompKit
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.CompKit
instance GHC.Classes.Ord Agda.TypeChecking.Monad.Base.CompKit
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.CompKit
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.AxiomData
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.AxiomData
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.DataOrRecSigData
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.DataOrRecSigData
instance GHC.Enum.Bounded Agda.TypeChecking.Monad.Base.ProjectionLikenessMissing
instance GHC.Enum.Enum Agda.TypeChecking.Monad.Base.ProjectionLikenessMissing
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.ProjectionLikenessMissing
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.ProjectionLikenessMissing
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.DatatypeData
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.DatatypeData
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.RecordData
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.RecordData
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.ConstructorData
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.ConstructorData
instance Agda.Utils.Null.Null Agda.TypeChecking.Monad.Base.Fields
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.Simplification
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.Simplification
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.Simplification
instance GHC.Base.Functor (Agda.TypeChecking.Monad.Base.Reduced no)
instance GHC.Base.Functor Agda.TypeChecking.Monad.Base.MaybeReduced
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.AllowedReduction
instance GHC.Ix.Ix Agda.TypeChecking.Monad.Base.AllowedReduction
instance GHC.Enum.Bounded Agda.TypeChecking.Monad.Base.AllowedReduction
instance GHC.Enum.Enum Agda.TypeChecking.Monad.Base.AllowedReduction
instance GHC.Classes.Ord Agda.TypeChecking.Monad.Base.AllowedReduction
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.AllowedReduction
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.AllowedReduction
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.ReduceDefs
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.TermHead
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.TermHead
instance GHC.Classes.Ord Agda.TypeChecking.Monad.Base.TermHead
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.TermHead
instance GHC.Generics.Generic (Agda.TypeChecking.Monad.Base.FunctionInverse' c)
instance GHC.Base.Functor Agda.TypeChecking.Monad.Base.FunctionInverse'
instance GHC.Show.Show c => GHC.Show.Show (Agda.TypeChecking.Monad.Base.FunctionInverse' c)
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.PrimitiveData
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.PrimitiveData
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.FunctionData
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.FunctionData
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.MutualId
instance GHC.Enum.Enum Agda.TypeChecking.Monad.Base.MutualId
instance GHC.Num.Num Agda.TypeChecking.Monad.Base.MutualId
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.MutualId
instance GHC.Classes.Ord Agda.TypeChecking.Monad.Base.MutualId
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.MutualId
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.Call
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.InstanceTable
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.InstanceTable
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.BuiltinSort
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.BuiltinSort
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.BuiltinSort
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.PrimitiveSortData
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.PrimitiveSortData
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.Defn
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.Defn
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.Definition
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.Definition
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.Signature
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.Signature
instance GHC.Generics.Generic (Agda.TypeChecking.Monad.Base.Builtin pf)
instance Data.Traversable.Traversable Agda.TypeChecking.Monad.Base.Builtin
instance Data.Foldable.Foldable Agda.TypeChecking.Monad.Base.Builtin
instance GHC.Base.Functor Agda.TypeChecking.Monad.Base.Builtin
instance GHC.Show.Show pf => GHC.Show.Show (Agda.TypeChecking.Monad.Base.Builtin pf)
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.HighlightingLevel
instance GHC.Read.Read Agda.TypeChecking.Monad.Base.HighlightingLevel
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.HighlightingLevel
instance GHC.Classes.Ord Agda.TypeChecking.Monad.Base.HighlightingLevel
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.HighlightingLevel
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.HighlightingMethod
instance GHC.Read.Read Agda.TypeChecking.Monad.Base.HighlightingMethod
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.HighlightingMethod
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.HighlightingMethod
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.UnquoteFlags
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.LetBinding
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.LetBinding
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.AbstractMode
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.AbstractMode
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.AbstractMode
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.OpaqueBlock
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.OpaqueBlock
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.ExpandHidden
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.ExpandHidden
instance GHC.Generics.Generic (Agda.TypeChecking.Monad.Base.Closure a)
instance Data.Foldable.Foldable Agda.TypeChecking.Monad.Base.Closure
instance GHC.Base.Functor Agda.TypeChecking.Monad.Base.Closure
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.IPClause
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.TCEnv
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.InteractionPoint
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.MetaInfo
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.CandidateKind
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.CandidateKind
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.Candidate
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.Candidate
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.CallInfo
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.CallInfo
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.TerminationError
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.TerminationError
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.ErasedDatatypeReason
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.ErasedDatatypeReason
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.NegativeUnification
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.NegativeUnification
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.UnificationFailure
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.UnificationFailure
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.SplitError
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.SplitError
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.InvalidFileNameReason
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.InvalidFileNameReason
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.InductionAndEta
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.InductionAndEta
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.IllegalRewriteRuleReason
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.IllegalRewriteRuleReason
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.IncorrectTypeForRewriteRelationReason
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.IncorrectTypeForRewriteRelationReason
instance GHC.Enum.Enum Agda.TypeChecking.Monad.Base.LHSOrPatSyn
instance GHC.Enum.Bounded Agda.TypeChecking.Monad.Base.LHSOrPatSyn
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.LHSOrPatSyn
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.LHSOrPatSyn
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.LHSOrPatSyn
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.PreScopeState
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.Listener
instance GHC.Show.Show a => GHC.Show.Show (Agda.TypeChecking.Monad.Base.ArgsCheckState a)
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.TypeCheckingProblem
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.MetaInstantiation
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.MetaVariable
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.PrimFun
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.PostScopeState
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.LoadedFileCache
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.Interface
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.Interface
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.Constraint
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.Constraint
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.ProblemConstraint
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.ProblemConstraint
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.UnquoteError
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.UnquoteError
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.TypeError
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.TypeError
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.Warning
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.Warning
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.TCWarning
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.TCWarning
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.ModuleInfo
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.PersistentTCState
instance GHC.Generics.Generic Agda.TypeChecking.Monad.Base.TCState
instance Agda.TypeChecking.Monad.Base.MonadTCM m => Agda.TypeChecking.Monad.Base.MonadTCM (Agda.TypeChecking.Monad.Base.BlockT m)
instance Agda.TypeChecking.Monad.Base.MonadTCState m => Agda.TypeChecking.Monad.Base.MonadTCState (Agda.TypeChecking.Monad.Base.BlockT m)
instance Agda.TypeChecking.Monad.Base.MonadTCEnv m => Agda.TypeChecking.Monad.Base.MonadTCEnv (Agda.TypeChecking.Monad.Base.BlockT m)
instance Agda.Interaction.Options.HasOptions.HasOptions m => Agda.Interaction.Options.HasOptions.HasOptions (Agda.TypeChecking.Monad.Base.BlockT m)
instance Agda.TypeChecking.Monad.Base.ReadTCState m => Agda.TypeChecking.Monad.Base.ReadTCState (Agda.TypeChecking.Monad.Base.BlockT m)
instance Control.Monad.Fail.MonadFail m => Control.Monad.Fail.MonadFail (Agda.TypeChecking.Monad.Base.BlockT m)
instance Control.Monad.IO.Class.MonadIO m => Control.Monad.IO.Class.MonadIO (Agda.TypeChecking.Monad.Base.BlockT m)
instance Control.Monad.Trans.Class.MonadTrans Agda.TypeChecking.Monad.Base.BlockT
instance GHC.Base.Monad m => GHC.Base.Monad (Agda.TypeChecking.Monad.Base.BlockT m)
instance GHC.Base.Monad m => GHC.Base.Applicative (Agda.TypeChecking.Monad.Base.BlockT m)
instance GHC.Base.Functor m => GHC.Base.Functor (Agda.TypeChecking.Monad.Base.BlockT m)
instance Agda.TypeChecking.Monad.Base.MonadReduce Agda.TypeChecking.Monad.Base.ReduceM
instance Agda.TypeChecking.Monad.Base.MonadReduce m => Agda.TypeChecking.Monad.Base.MonadReduce (Agda.Utils.Update.ChangeT m)
instance Agda.TypeChecking.Monad.Base.MonadReduce m => Agda.TypeChecking.Monad.Base.MonadReduce (Control.Monad.Trans.Except.ExceptT err m)
instance Agda.TypeChecking.Monad.Base.MonadReduce m => Agda.TypeChecking.Monad.Base.MonadReduce (Control.Monad.Trans.Identity.IdentityT m)
instance Agda.TypeChecking.Monad.Base.MonadReduce m => Agda.TypeChecking.Monad.Base.MonadReduce (Agda.Utils.ListT.ListT m)
instance Agda.TypeChecking.Monad.Base.MonadReduce m => Agda.TypeChecking.Monad.Base.MonadReduce (Control.Monad.Trans.Maybe.MaybeT m)
instance Agda.TypeChecking.Monad.Base.MonadReduce m => Agda.TypeChecking.Monad.Base.MonadReduce (Control.Monad.Trans.Reader.ReaderT r m)
instance Agda.TypeChecking.Monad.Base.MonadReduce m => Agda.TypeChecking.Monad.Base.MonadReduce (Control.Monad.Trans.State.Lazy.StateT w m)
instance (GHC.Base.Monoid w, Agda.TypeChecking.Monad.Base.MonadReduce m) => Agda.TypeChecking.Monad.Base.MonadReduce (Control.Monad.Trans.Writer.Lazy.WriterT w m)
instance Agda.TypeChecking.Monad.Base.MonadReduce m => Agda.TypeChecking.Monad.Base.MonadReduce (Agda.TypeChecking.Monad.Base.BlockT m)
instance Control.Monad.IO.Class.MonadIO m => Agda.TypeChecking.Monad.Base.MonadReduce (Agda.TypeChecking.Monad.Base.TCMT m)
instance GHC.Base.Monad m => Agda.TypeChecking.Monad.Base.MonadBlock (Agda.TypeChecking.Monad.Base.BlockT m)
instance Agda.TypeChecking.Monad.Base.ReadTCState m => Agda.TypeChecking.Monad.Base.ReadTCState (Agda.Utils.ListT.ListT m)
instance Agda.TypeChecking.Monad.Base.ReadTCState m => Agda.TypeChecking.Monad.Base.ReadTCState (Agda.Utils.Update.ChangeT m)
instance Agda.TypeChecking.Monad.Base.ReadTCState m => Agda.TypeChecking.Monad.Base.ReadTCState (Control.Monad.Trans.Except.ExceptT err m)
instance Agda.TypeChecking.Monad.Base.ReadTCState m => Agda.TypeChecking.Monad.Base.ReadTCState (Control.Monad.Trans.Identity.IdentityT m)
instance Agda.TypeChecking.Monad.Base.ReadTCState m => Agda.TypeChecking.Monad.Base.ReadTCState (Control.Monad.Trans.Maybe.MaybeT m)
instance Agda.TypeChecking.Monad.Base.ReadTCState m => Agda.TypeChecking.Monad.Base.ReadTCState (Control.Monad.Trans.Reader.ReaderT r m)
instance Agda.TypeChecking.Monad.Base.ReadTCState m => Agda.TypeChecking.Monad.Base.ReadTCState (Control.Monad.Trans.State.Lazy.StateT s m)
instance (GHC.Base.Monoid w, Agda.TypeChecking.Monad.Base.ReadTCState m) => Agda.TypeChecking.Monad.Base.ReadTCState (Control.Monad.Trans.Writer.Lazy.WriterT w m)
instance Agda.TypeChecking.Monad.Base.ReadTCState Agda.TypeChecking.Monad.Base.ReduceM
instance Agda.Interaction.Options.HasOptions.HasOptions Agda.TypeChecking.Monad.Base.ReduceM
instance Control.Monad.IO.Class.MonadIO m => Agda.TypeChecking.Monad.Base.ReadTCState (Agda.TypeChecking.Monad.Base.TCMT m)
instance Agda.TypeChecking.Monad.Base.HasFresh i => Agda.TypeChecking.Monad.Base.MonadFresh i Agda.TypeChecking.Monad.Base.TCM
instance Agda.TypeChecking.Monad.Base.HasFresh Agda.Syntax.Common.MetaId
instance Agda.TypeChecking.Monad.Base.HasFresh Agda.TypeChecking.Monad.Base.MutualId
instance Agda.TypeChecking.Monad.Base.HasFresh Agda.Syntax.Common.InteractionId
instance Agda.TypeChecking.Monad.Base.HasFresh Agda.Syntax.Common.NameId
instance Agda.TypeChecking.Monad.Base.HasFresh Agda.Syntax.Common.OpaqueId
instance Agda.TypeChecking.Monad.Base.HasFresh GHC.Types.Int
instance Agda.TypeChecking.Monad.Base.HasFresh Agda.Syntax.Common.ProblemId
instance Agda.TypeChecking.Monad.Base.HasFresh Agda.TypeChecking.Monad.Base.CheckpointId
instance Control.Monad.IO.Class.MonadIO m => Agda.TypeChecking.Monad.Base.MonadTCM (Agda.TypeChecking.Monad.Base.TCMT m)
instance Agda.TypeChecking.Monad.Base.MonadTCM tcm => Agda.TypeChecking.Monad.Base.MonadTCM (Agda.Utils.Update.ChangeT tcm)
instance Agda.TypeChecking.Monad.Base.MonadTCM tcm => Agda.TypeChecking.Monad.Base.MonadTCM (Control.Monad.Trans.Except.ExceptT err tcm)
instance Agda.TypeChecking.Monad.Base.MonadTCM tcm => Agda.TypeChecking.Monad.Base.MonadTCM (Control.Monad.Trans.Identity.IdentityT tcm)
instance Agda.TypeChecking.Monad.Base.MonadTCM tcm => Agda.TypeChecking.Monad.Base.MonadTCM (Agda.Utils.ListT.ListT tcm)
instance Agda.TypeChecking.Monad.Base.MonadTCM tcm => Agda.TypeChecking.Monad.Base.MonadTCM (Control.Monad.Trans.Maybe.MaybeT tcm)
instance Agda.TypeChecking.Monad.Base.MonadTCM tcm => Agda.TypeChecking.Monad.Base.MonadTCM (Control.Monad.Trans.Reader.ReaderT r tcm)
instance Agda.TypeChecking.Monad.Base.MonadTCM tcm => Agda.TypeChecking.Monad.Base.MonadTCM (Control.Monad.Trans.State.Lazy.StateT s tcm)
instance (GHC.Base.Monoid w, Agda.TypeChecking.Monad.Base.MonadTCM tcm) => Agda.TypeChecking.Monad.Base.MonadTCM (Control.Monad.Trans.Writer.Lazy.WriterT w tcm)
instance Control.Monad.IO.Class.MonadIO m => Agda.Interaction.Options.HasOptions.HasOptions (Agda.TypeChecking.Monad.Base.TCMT m)
instance Agda.TypeChecking.Monad.Base.MonadTCState m => Agda.TypeChecking.Monad.Base.MonadTCState (Control.Monad.Trans.Maybe.MaybeT m)
instance Agda.TypeChecking.Monad.Base.MonadTCState m => Agda.TypeChecking.Monad.Base.MonadTCState (Agda.Utils.ListT.ListT m)
instance Agda.TypeChecking.Monad.Base.MonadTCState m => Agda.TypeChecking.Monad.Base.MonadTCState (Control.Monad.Trans.Except.ExceptT err m)
instance Agda.TypeChecking.Monad.Base.MonadTCState m => Agda.TypeChecking.Monad.Base.MonadTCState (Control.Monad.Trans.Reader.ReaderT r m)
instance Agda.TypeChecking.Monad.Base.MonadTCState m => Agda.TypeChecking.Monad.Base.MonadTCState (Control.Monad.Trans.State.Lazy.StateT s m)
instance Agda.TypeChecking.Monad.Base.MonadTCState m => Agda.TypeChecking.Monad.Base.MonadTCState (Agda.Utils.Update.ChangeT m)
instance Agda.TypeChecking.Monad.Base.MonadTCState m => Agda.TypeChecking.Monad.Base.MonadTCState (Control.Monad.Trans.Identity.IdentityT m)
instance (GHC.Base.Monoid w, Agda.TypeChecking.Monad.Base.MonadTCState m) => Agda.TypeChecking.Monad.Base.MonadTCState (Control.Monad.Trans.Writer.Lazy.WriterT w m)
instance Control.Monad.IO.Class.MonadIO m => Agda.TypeChecking.Monad.Base.MonadTCState (Agda.TypeChecking.Monad.Base.TCMT m)
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.TCState
instance Agda.TypeChecking.Monad.Base.MonadStConcreteNames Agda.TypeChecking.Monad.Base.TCM
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.Interface
instance Agda.Syntax.Position.HasRange Agda.TypeChecking.Monad.Base.ProblemConstraint
instance Agda.Syntax.Position.HasRange Agda.TypeChecking.Monad.Base.Constraint
instance Agda.TypeChecking.Free.Lazy.Free Agda.TypeChecking.Monad.Base.Constraint
instance Agda.Syntax.Internal.Generic.TermLike Agda.TypeChecking.Monad.Base.Constraint
instance Agda.Syntax.Internal.MetaVars.AllMetas Agda.TypeChecking.Monad.Base.Constraint
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.Listener
instance GHC.Classes.Ord Agda.TypeChecking.Monad.Base.Listener
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.MetaInstantiation
instance Agda.Syntax.Position.HasRange Agda.TypeChecking.Monad.Base.MetaVariable
instance Agda.Syntax.Position.SetRange Agda.TypeChecking.Monad.Base.MetaVariable
instance Agda.Syntax.Common.LensModality Agda.TypeChecking.Monad.Base.MetaVariable
instance Agda.Syntax.Common.LensRelevance Agda.TypeChecking.Monad.Base.MetaVariable
instance Agda.Syntax.Common.LensQuantity Agda.TypeChecking.Monad.Base.MetaVariable
instance Agda.TypeChecking.Monad.Base.LensClosure Agda.TypeChecking.Monad.Base.MetaVariable Agda.Syntax.Position.Range
instance Agda.Syntax.Position.HasRange Agda.TypeChecking.Monad.Base.TCWarning
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.TCWarning
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.TCErr
instance Agda.Syntax.Position.HasRange Agda.TypeChecking.Monad.Base.TCErr
instance GHC.Exception.Type.Exception Agda.TypeChecking.Monad.Base.TCErr
instance GHC.Base.Functor Agda.TypeChecking.Monad.Base.ReduceM
instance GHC.Base.Applicative Agda.TypeChecking.Monad.Base.ReduceM
instance GHC.Base.Monad Agda.TypeChecking.Monad.Base.ReduceM
instance Control.Monad.Fail.MonadFail Agda.TypeChecking.Monad.Base.ReduceM
instance Agda.TypeChecking.Monad.Base.MonadTCEnv Agda.TypeChecking.Monad.Base.ReduceM
instance GHC.Base.Monad m => Agda.TypeChecking.Monad.Base.MonadBlock (Control.Monad.Trans.Except.ExceptT Agda.TypeChecking.Monad.Base.TCErr m)
instance GHC.Base.Functor m => GHC.Base.Functor (Agda.TypeChecking.Monad.Base.TCMT m)
instance GHC.Base.Applicative m => GHC.Base.Applicative (Agda.TypeChecking.Monad.Base.TCMT m)
instance Control.Monad.Trans.Class.MonadTrans Agda.TypeChecking.Monad.Base.TCMT
instance GHC.Base.Monad m => GHC.Base.Monad (Agda.TypeChecking.Monad.Base.TCMT m)
instance Control.Monad.IO.Class.MonadIO m => Control.Monad.Fail.MonadFail (Agda.TypeChecking.Monad.Base.TCMT m)
instance Control.Monad.IO.Class.MonadIO m => Control.Monad.IO.Class.MonadIO (Agda.TypeChecking.Monad.Base.TCMT m)
instance Control.Monad.Fix.MonadFix m => Control.Monad.Fix.MonadFix (Agda.TypeChecking.Monad.Base.TCMT m)
instance Control.Monad.IO.Class.MonadIO m => Agda.TypeChecking.Monad.Base.MonadTCEnv (Agda.TypeChecking.Monad.Base.TCMT m)
instance Agda.TypeChecking.Monad.Base.MonadBlock Agda.TypeChecking.Monad.Base.TCM
instance Control.Monad.Error.Class.MonadError Agda.TypeChecking.Monad.Base.TCErr Agda.TypeChecking.Monad.Base.TCM
instance Agda.Utils.Impossible.CatchImpossible Agda.TypeChecking.Monad.Base.TCM
instance (Data.String.IsString a, Control.Monad.IO.Class.MonadIO m) => Data.String.IsString (Agda.TypeChecking.Monad.Base.TCMT m a)
instance (Control.Monad.IO.Class.MonadIO m, GHC.Base.Semigroup a) => GHC.Base.Semigroup (Agda.TypeChecking.Monad.Base.TCMT m a)
instance (Control.Monad.IO.Class.MonadIO m, GHC.Base.Semigroup a, GHC.Base.Monoid a) => GHC.Base.Monoid (Agda.TypeChecking.Monad.Base.TCMT m a)
instance (Control.Monad.IO.Class.MonadIO m, Agda.Utils.Null.Null a) => Agda.Utils.Null.Null (Agda.TypeChecking.Monad.Base.TCMT m a)
instance Agda.Utils.Benchmark.MonadBench Agda.TypeChecking.Monad.Base.TCM
instance Agda.Utils.Null.Null (Agda.TypeChecking.Monad.Base.TCM Agda.Syntax.Common.Pretty.Doc)
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.TCErr
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.PreScopeState
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.PostScopeState
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.TCState
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.PersistentTCState
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.LoadedFileCache
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.ModuleInfo
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Interface
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.ProblemConstraint
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Constraint
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.MetaVariable
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Listener
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.MetaInstantiation
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.TypeCheckingProblem
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.PrimFun
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Warning
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.TCWarning
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.UnquoteError
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.TypeError
instance Agda.TypeChecking.Monad.Base.MonadBlock m => Agda.TypeChecking.Monad.Base.MonadBlock (Control.Monad.Trans.Maybe.MaybeT m)
instance Agda.TypeChecking.Monad.Base.MonadBlock m => Agda.TypeChecking.Monad.Base.MonadBlock (Control.Monad.Trans.Reader.ReaderT e m)
instance Agda.TypeChecking.Monad.Base.MonadTCEnv m => Agda.TypeChecking.Monad.Base.MonadTCEnv (Agda.Utils.Update.ChangeT m)
instance Agda.TypeChecking.Monad.Base.MonadTCEnv m => Agda.TypeChecking.Monad.Base.MonadTCEnv (Control.Monad.Trans.Except.ExceptT err m)
instance Agda.TypeChecking.Monad.Base.MonadTCEnv m => Agda.TypeChecking.Monad.Base.MonadTCEnv (Control.Monad.Trans.Identity.IdentityT m)
instance Agda.TypeChecking.Monad.Base.MonadTCEnv m => Agda.TypeChecking.Monad.Base.MonadTCEnv (Control.Monad.Trans.Maybe.MaybeT m)
instance Agda.TypeChecking.Monad.Base.MonadTCEnv m => Agda.TypeChecking.Monad.Base.MonadTCEnv (Control.Monad.Trans.Reader.ReaderT r m)
instance Agda.TypeChecking.Monad.Base.MonadTCEnv m => Agda.TypeChecking.Monad.Base.MonadTCEnv (Control.Monad.Trans.State.Lazy.StateT s m)
instance (GHC.Base.Monoid w, Agda.TypeChecking.Monad.Base.MonadTCEnv m) => Agda.TypeChecking.Monad.Base.MonadTCEnv (Control.Monad.Trans.Writer.Lazy.WriterT w m)
instance Agda.TypeChecking.Monad.Base.MonadTCEnv m => Agda.TypeChecking.Monad.Base.MonadTCEnv (Agda.Utils.ListT.ListT m)
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.LHSOrPatSyn
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.IncorrectTypeForRewriteRelationReason
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.IllegalRewriteRuleReason
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.DataOrRecordE
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.InductionAndEta
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.InvalidFileNameReason
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.SplitError
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.UnificationFailure
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.NegativeUnification
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.ErasedDatatypeReason
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.TerminationError
instance Agda.Syntax.Position.HasRange Agda.TypeChecking.Monad.Base.CallInfo
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.CallInfo
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.CallInfo
instance Agda.TypeChecking.Free.Lazy.Free Agda.TypeChecking.Monad.Base.Candidate
instance Agda.Syntax.Common.HasOverlapMode Agda.TypeChecking.Monad.Base.Candidate
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Candidate
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.CandidateKind
instance Agda.TypeChecking.Monad.Base.LensClosure (Agda.TypeChecking.Monad.Base.Closure a) a
instance Agda.TypeChecking.Monad.Base.LensClosure Agda.TypeChecking.Monad.Base.MetaInfo Agda.Syntax.Position.Range
instance Agda.Syntax.Common.LensIsAbstract Agda.TypeChecking.Monad.Base.MetaInfo
instance Agda.Syntax.Common.LensModality Agda.TypeChecking.Monad.Base.MetaInfo
instance Agda.Syntax.Common.LensQuantity Agda.TypeChecking.Monad.Base.MetaInfo
instance Agda.Syntax.Common.LensRelevance Agda.TypeChecking.Monad.Base.MetaInfo
instance Agda.Syntax.Position.HasRange Agda.TypeChecking.Monad.Base.MetaInfo
instance Agda.Syntax.Position.SetRange Agda.TypeChecking.Monad.Base.MetaInfo
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.MetaInfo
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.InteractionPoints
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.InteractionPoint
instance Agda.Utils.BiMap.HasTag Agda.TypeChecking.Monad.Base.InteractionPoint
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.InteractionPoint
instance Agda.TypeChecking.Monad.Base.LensTCEnv (Agda.TypeChecking.Monad.Base.Closure a)
instance Agda.Syntax.Common.LensIsAbstract (Agda.TypeChecking.Monad.Base.Closure a)
instance Agda.TypeChecking.Monad.Base.LensTCEnv Agda.TypeChecking.Monad.Base.TCEnv
instance GHC.Show.Show a => GHC.Show.Show (Agda.TypeChecking.Monad.Base.Closure a)
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange (Agda.TypeChecking.Monad.Base.Closure a)
instance Agda.Syntax.Common.LensIsAbstract Agda.TypeChecking.Monad.Base.TCEnv
instance Agda.Syntax.Common.LensIsOpaque Agda.TypeChecking.Monad.Base.TCEnv
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.IPClause
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.TypeChecking.Monad.Base.Closure a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.TypeChecking.Monad.Base.Closure a)
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.IPClause
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.TCEnv
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.ExpandHidden
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.OpaqueBlock
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Base.OpaqueBlock
instance Data.Hashable.Class.Hashable Agda.TypeChecking.Monad.Base.OpaqueBlock
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.OpaqueBlock
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.AbstractMode
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.LetBinding
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.UnquoteFlags
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.HighlightingMethod
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.HighlightingLevel
instance Control.DeepSeq.NFData pf => Control.DeepSeq.NFData (Agda.TypeChecking.Monad.Base.Builtin pf)
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.Signature
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Signature
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.Definitions
instance Agda.Syntax.Common.LensArgInfo Agda.TypeChecking.Monad.Base.Definition
instance Agda.Syntax.Common.LensModality Agda.TypeChecking.Monad.Base.Definition
instance Agda.Syntax.Common.LensQuantity Agda.TypeChecking.Monad.Base.Definition
instance Agda.Syntax.Common.LensRelevance Agda.TypeChecking.Monad.Base.Definition
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.Definition
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.Definition
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Definition
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.Defn
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.Defn
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Defn
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.PrimitiveSortData
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.PrimitiveSortData
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.BuiltinSort
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.BuiltinSort
instance GHC.Base.Semigroup Agda.TypeChecking.Monad.Base.InstanceTable
instance GHC.Base.Monoid Agda.TypeChecking.Monad.Base.InstanceTable
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.InstanceTable
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.InstanceTable
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.Call
instance Agda.Syntax.Position.HasRange Agda.TypeChecking.Monad.Base.Call
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Call
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.MutualId
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.FunctionData
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.FunctionData
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.PrimitiveData
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.PrimitiveData
instance Agda.Syntax.Common.Pretty.Pretty c => Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.Monad.Base.FunctionInverse' c)
instance Agda.Syntax.Position.KillRange c => Agda.Syntax.Position.KillRange (Agda.TypeChecking.Monad.Base.FunctionInverse' c)
instance Control.DeepSeq.NFData c => Control.DeepSeq.NFData (Agda.TypeChecking.Monad.Base.FunctionInverse' c)
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.TermHead
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.TermHead
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.TermHead
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.ReduceDefs
instance Agda.Utils.SmallSet.SmallSetElement Agda.TypeChecking.Monad.Base.AllowedReduction
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.AllowedReduction
instance Agda.Syntax.Internal.Elim.IsProjElim e => Agda.Syntax.Internal.Elim.IsProjElim (Agda.TypeChecking.Monad.Base.MaybeReduced e)
instance Agda.Utils.Null.Null Agda.TypeChecking.Monad.Base.Simplification
instance GHC.Base.Semigroup Agda.TypeChecking.Monad.Base.Simplification
instance GHC.Base.Monoid Agda.TypeChecking.Monad.Base.Simplification
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Simplification
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.ConstructorData
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.ConstructorData
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.RecordData
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.RecordData
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.DatatypeData
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.DatatypeData
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.ProjectionLikenessMissing
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.ProjectionLikenessMissing
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.ProjectionLikenessMissing
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.DataOrRecSigData
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.DataOrRecSigData
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.AxiomData
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.CompKit
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.CompKit
instance Agda.Utils.SmallSet.SmallSetElement Agda.TypeChecking.Monad.Base.FunctionFlag
instance Agda.Syntax.Position.KillRange (Agda.Utils.SmallSet.SmallSet Agda.TypeChecking.Monad.Base.FunctionFlag)
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.FunctionFlag
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.FunctionFlag
instance Agda.Syntax.Common.PatternMatchingAllowed Agda.TypeChecking.Monad.Base.EtaEquality
instance Agda.Syntax.Common.CopatternMatchingAllowed Agda.TypeChecking.Monad.Base.EtaEquality
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.EtaEquality
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.EtaEquality
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.Projection
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.Projection
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Projection
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.ProjLams
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.ProjLams
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.ProjLams
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.ExtLamInfo
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.ExtLamInfo
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.System
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.System
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.CompiledRepresentation
instance Agda.Syntax.Position.HasRange Agda.TypeChecking.Monad.Base.CompilerPragma
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.CompilerPragma
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.IsForced
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.IsForced
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.Polarity
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.Polarity
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Polarity
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.NumGeneralizableArgs
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.NumGeneralizableArgs
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.InstanceInfo
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.InstanceInfo
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.RewriteRuleMap
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.RewriteRule
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.RewriteRule
instance Agda.Syntax.Internal.Generic.TermLike Agda.TypeChecking.Monad.Base.NLPat
instance Agda.Syntax.Internal.MetaVars.AllMetas Agda.TypeChecking.Monad.Base.NLPat
instance Agda.Syntax.Internal.Generic.TermLike Agda.TypeChecking.Monad.Base.NLPType
instance Agda.Syntax.Internal.MetaVars.AllMetas Agda.TypeChecking.Monad.Base.NLPType
instance Agda.Syntax.Internal.Generic.TermLike Agda.TypeChecking.Monad.Base.NLPSort
instance Agda.Syntax.Internal.MetaVars.AllMetas Agda.TypeChecking.Monad.Base.NLPSort
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.NLPat
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.NLPType
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.NLPSort
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.NLPat
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.NLPType
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.NLPSort
instance Agda.TypeChecking.Free.Lazy.Free Agda.TypeChecking.Monad.Base.DisplayForm
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.DisplayForm
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.DisplayForm
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.DisplayForm
instance Agda.TypeChecking.Free.Lazy.Free Agda.TypeChecking.Monad.Base.DisplayTerm
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.DisplayTerm
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.DisplayTerm
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.DisplayTerm
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.Sections
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.Section
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.Section
instance Control.DeepSeq.NFData t => Control.DeepSeq.NFData (Agda.TypeChecking.Monad.Base.IPBoundary' t)
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Overapplied
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.NamedMeta
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.RunMetaOccursCheck
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.PrincipalArgTypeMetas
instance Agda.Syntax.Common.LensModality Agda.TypeChecking.Monad.Base.RemoteMetaVariable
instance Agda.Syntax.Common.LensRelevance Agda.TypeChecking.Monad.Base.RemoteMetaVariable
instance Agda.Syntax.Common.LensQuantity Agda.TypeChecking.Monad.Base.RemoteMetaVariable
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.RemoteMetaVariable
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Instantiation
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Frozen
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.GeneralizedValue
instance Agda.Syntax.Position.KillRange Agda.TypeChecking.Monad.Base.DoGeneralize
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.DoGeneralize
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.Monad.Base.Judgement a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.TypeChecking.Monad.Base.Judgement a)
instance Agda.Utils.Functor.Decoration Agda.TypeChecking.Monad.Base.Open
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.Monad.Base.Open a)
instance Agda.Syntax.Position.KillRange a => Agda.Syntax.Position.KillRange (Agda.TypeChecking.Monad.Base.Open a)
instance Control.DeepSeq.NFData a => Control.DeepSeq.NFData (Agda.TypeChecking.Monad.Base.Open a)
instance Agda.TypeChecking.Free.Lazy.Free Agda.TypeChecking.Monad.Base.CompareAs
instance Agda.Syntax.Internal.Generic.TermLike Agda.TypeChecking.Monad.Base.CompareAs
instance Agda.Syntax.Internal.MetaVars.AllMetas Agda.TypeChecking.Monad.Base.CompareAs
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.CompareAs
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.CompareAs
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.CompareDirection
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.Comparison
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Comparison
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.WhyCheckModality
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.ForeignCode
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.ModuleCheckMode
instance Agda.TypeChecking.Monad.Base.MonadStConcreteNames m => Agda.TypeChecking.Monad.Base.MonadStConcreteNames (Control.Monad.Trans.Identity.IdentityT m)
instance Agda.TypeChecking.Monad.Base.MonadStConcreteNames m => Agda.TypeChecking.Monad.Base.MonadStConcreteNames (Control.Monad.Trans.Reader.ReaderT r m)
instance Agda.TypeChecking.Monad.Base.MonadStConcreteNames m => Agda.TypeChecking.Monad.Base.MonadStConcreteNames (Control.Monad.Trans.State.Lazy.StateT s m)
instance Agda.TypeChecking.Monad.Base.FreshName (Agda.Syntax.Position.Range, GHC.Base.String)
instance Agda.TypeChecking.Monad.Base.FreshName GHC.Base.String
instance Agda.TypeChecking.Monad.Base.FreshName Agda.Syntax.Position.Range
instance Agda.TypeChecking.Monad.Base.FreshName ()
instance GHC.Show.Show Agda.TypeChecking.Monad.Base.CheckpointId
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.Base.CheckpointId
instance Agda.TypeChecking.Monad.Base.MonadFresh i m => Agda.TypeChecking.Monad.Base.MonadFresh i (Control.Monad.Trans.Reader.ReaderT r m)
instance Agda.TypeChecking.Monad.Base.MonadFresh i m => Agda.TypeChecking.Monad.Base.MonadFresh i (Control.Monad.Trans.State.Lazy.StateT s m)
instance Agda.TypeChecking.Monad.Base.MonadFresh i m => Agda.TypeChecking.Monad.Base.MonadFresh i (Agda.Utils.ListT.ListT m)
instance Agda.TypeChecking.Monad.Base.MonadFresh i m => Agda.TypeChecking.Monad.Base.MonadFresh i (Control.Monad.Trans.Identity.IdentityT m)
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.TypeCheckAction
instance Agda.Utils.Null.Null Agda.TypeChecking.Monad.Base.MutualBlock
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.MutualBlock
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.DisambiguatedName
instance Control.DeepSeq.NFData (Agda.Utils.BiMap.BiMap Agda.Syntax.TopLevelModuleName.RawTopLevelModuleName Agda.Syntax.TopLevelModuleName.Boot.ModuleNameHash)
instance Control.DeepSeq.NFData Agda.TypeChecking.Monad.Base.Warning.RecordFieldWarning


-- | This module contains the definition of hereditary substitution and
--   application operating on internal syntax which is in β-normal form (β
--   including projection reductions).
--   
--   Further, it contains auxiliary functions which rely on substitution
--   but not on reduction.
module Agda.TypeChecking.Substitute
data TelV a
TelV :: Tele (Dom a) -> a -> TelV a
[theTel] :: TelV a -> Tele (Dom a)
[theCore] :: TelV a -> a
type TelView = TelV Type

-- | Performs void (<tt>noAbs</tt>) abstraction over telescope.
class TeleNoAbs a
teleNoAbs :: TeleNoAbs a => a -> Term -> Term

-- | A sort can either be small (Set l, Prop l, Size, ...) or large (Setω
--   n).
data SizeOfSort
SizeOfSort :: Univ -> Integer -> SizeOfSort
[szSortUniv] :: SizeOfSort -> Univ
[szSortSize] :: SizeOfSort -> Integer
pattern SmallSort :: Univ -> SizeOfSort
pattern LargeSort :: Univ -> Integer -> SizeOfSort
sort :: Sort -> Type
mkLam :: Arg ArgName -> Term -> Term
funSort :: Sort -> Sort -> Sort

-- | If <tt>permute π : [a]Γ -&gt; [a]Δ</tt>, then <tt>applySubst (renaming
--   _ π) : Term Γ -&gt; Term Δ</tt>
renaming :: forall a. DeBruijn a => Impossible -> Permutation -> Substitution' a
piSort :: Dom Term -> Sort -> Abs Sort -> Sort
univSort :: Sort -> Sort

-- | <pre>
--   mkPi dom t = telePi (telFromList [dom]) t
--   </pre>
mkPi :: Dom (ArgName, Type) -> Type -> Type
lamView :: Term -> ([Arg ArgName], Term)

-- | Apply <tt>Elims</tt> while using the given function to report
--   ill-typed redexes. Recursive calls for <tt>applyE</tt> and
--   <tt>applySubst</tt> happen at type <tt>t</tt> to propagate the same
--   strategy to subtrees.
applyTermE :: forall t. (Coercible Term t, Apply t, EndoSubst t) => (Empty -> Term -> Elims -> Term) -> t -> Elims -> t

-- | <tt>defApp f us vs</tt> applies <tt>Def f us</tt> to further arguments
--   <tt>vs</tt>, eliminating top projection redexes. If <tt>us</tt> is not
--   empty, we cannot have a projection redex, since the record argument is
--   the first one.
defApp :: QName -> Elims -> Elims -> Term

-- | Eliminate a constructed term.
conApp :: forall t. (Coercible t Term, Apply t) => (Empty -> Term -> Elims -> Term) -> ConHead -> ConInfo -> Elims -> Elims -> Term

-- | If <tt>v</tt> is a record or constructed value, <tt>canProject f
--   v</tt> returns its field <tt>f</tt>.
canProject :: QName -> Term -> Maybe (Arg Term)
relToDontCare :: LensRelevance a => a -> Term -> Term
argToDontCare :: Arg Term -> Term

-- | <pre>
--   (x:A)-&gt;B(x) <a>piApply</a> [u] = B(u)
--   </pre>
--   
--   Precondition: The type must contain the right number of pis without
--   having to perform any reduction.
--   
--   <tt>piApply</tt> is potentially unsafe, the monadic <tt>piApplyM</tt>
--   is preferable.
piApply :: Type -> Args -> Type
applyNLPatSubst :: TermSubst a => Substitution' NLPat -> a -> a

-- | Abstract over a telescope in a term, producing lambdas. Dumb
--   abstraction: Always produces <a>Abs</a>, never <a>NoAbs</a>.
--   
--   The implementation is sound because <a>Telescope</a> does not use
--   <a>NoAbs</a>.
teleLam :: Telescope -> Term -> Term

-- | Everything will be an <a>Abs</a>.
telePi_ :: Telescope -> Type -> Type
namedTelVars :: Int -> Telescope -> [NamedArg DeBruijnPattern]
telVars :: Int -> Telescope -> [Arg DeBruijnPattern]
abstractArgs :: Abstract a => Args -> a -> a

-- | If <tt>permute π : [a]Γ -&gt; [a]Δ</tt>, then <tt>applySubst
--   (renamingR π) : Term Δ -&gt; Term Γ</tt>
renamingR :: DeBruijn a => Permutation -> Substitution' a

-- | The permutation should permute the corresponding context.
--   (right-to-left list)
renameP :: Subst a => Impossible -> Permutation -> a -> a
applySubstTerm :: forall t. (Coercible t Term, EndoSubst t, Apply t) => Substitution' t -> t -> t
levelTm :: Level -> Term
applyNLSubstToDom :: SubstWith NLPat a => Substitution' NLPat -> Dom a -> Dom a
fromPatternSubstitution :: PatternSubstitution -> Substitution
applyPatSubst :: TermSubst a => PatternSubstitution -> a -> a
usePatOrigin :: PatOrigin -> Pattern' a -> Pattern' a
usePatternInfo :: PatternInfo -> Pattern' a -> Pattern' a

-- | <pre>
--   projDropParsApply proj o args = <a>projDropPars</a> proj o `<tt>apply'</tt> args
--   </pre>
--   
--   This function is an optimization, saving us from construction lambdas
--   we immediately remove through application.
projDropParsApply :: Projection -> ProjOrigin -> Relevance -> Args -> Term

-- | Takes off all exposed function domains from the given type. This means
--   that it does not reduce to expose <tt>Pi</tt>-types.
telView' :: Type -> TelView

-- | <tt>telView'UpTo n t</tt> takes off the first <tt>n</tt> exposed
--   function types of <tt>t</tt>. Takes off all (exposed ones) if <tt>n
--   &lt; 0</tt>.
telView'UpTo :: Int -> Type -> TelView

-- | Add given binding to the front of the telescope.
absV :: Dom a -> ArgName -> TelV a -> TelV a

-- | Turn a typed binding <tt>(x1 .. xn : A)</tt> into a telescope.
bindsToTel' :: (Name -> a) -> [Name] -> Dom Type -> ListTel' a
bindsToTel :: [Name] -> Dom Type -> ListTel
bindsToTel'1 :: (Name -> a) -> List1 Name -> Dom Type -> ListTel' a
bindsToTel1 :: List1 Name -> Dom Type -> ListTel

-- | Turn a typed binding <tt>(x1 .. xn : A)</tt> into a telescope.
namedBindsToTel :: [NamedArg Name] -> Type -> Telescope
domFromNamedArgName :: NamedArg Name -> Dom ()
namedBindsToTel1 :: List1 (NamedArg Name) -> Type -> Telescope
mkPiSort :: Dom Type -> Abs Type -> Sort
unlamView :: [Arg ArgName] -> Term -> Term
telePi' :: (Abs Type -> Abs Type) -> Telescope -> Type -> Type

-- | Uses free variable analysis to introduce <a>NoAbs</a> bindings.
telePi :: Telescope -> Type -> Type

-- | Only abstract the visible components of the telescope, and all that
--   bind variables. Everything will be an <a>Abs</a>! Caution: quadratic
--   time!
telePiVisible :: Telescope -> Type -> Type

-- | Given arguments <tt>vs : tel</tt> (vector typing), extract their
--   individual types. Returns <tt>Nothing</tt> is <tt>tel</tt> is not long
--   enough.
typeArgsWithTel :: Telescope -> [Term] -> Maybe [Dom Type]

-- | In compiled clauses, the variables in the clause body are relative to
--   the pattern variables (including dot patterns) instead of the clause
--   telescope.
compiledClauseBody :: Clause -> Maybe Term

-- | <tt>univSort' univInf s</tt> gets the next higher sort of <tt>s</tt>,
--   if it is known (i.e. it is not just <tt>UnivSort s</tt>).
--   
--   Precondition: <tt>s</tt> is reduced
univSort' :: Sort -> Either Blocker Sort
ssort :: Level -> Type

-- | Returns <tt>Left blocker</tt> for unknown (blocked) sorts, and
--   otherwise returns <tt>Right s</tt> where <tt>s</tt> indicates the size
--   and fibrancy.
sizeOfSort :: Sort -> Either Blocker SizeOfSort
isSmallSort :: Sort -> Bool

-- | Compute the sort of a function type from the sorts of its domain and
--   codomain.
--   
--   This function should only be called on reduced sorts, since the
--   <tt>LevelUniv</tt> rules should only apply when the sort does not
--   reduce to <tt>Set</tt>.
funSort' :: Sort -> Sort -> Either Blocker Sort

-- | Given two levels <tt>a</tt> and <tt>b</tt>, compute <tt>a ⊔ b</tt> and
--   return its canonical form.
levelLub :: Level -> Level -> Level

-- | Compute the sort of a pi type from the sorts of its domain and
--   codomain. This function should only be called on reduced sorts, since
--   the <tt>LevelUniv</tt> rules should only apply when the sort doesn't
--   reduce to <tt>Set</tt>
piSort' :: Dom Term -> Sort -> Abs Sort -> Either Blocker Sort
levelMax :: Integer -> [PlusLevel] -> Level

-- | Substitutions.
data Substitution' a

-- | Identity substitution. <tt>Γ ⊢ IdS : Γ</tt>
IdS :: Substitution' a

-- | Empty substitution, lifts from the empty context. First argument is
--   <tt><b>IMPOSSIBLE</b></tt>. Apply this to closed terms you want to use
--   in a non-empty context. <tt>Γ ⊢ EmptyS : ()</tt>
EmptyS :: Impossible -> Substitution' a

-- | Substitution extension, `<tt>cons'</tt>. <tt> Γ ⊢ u : Aρ Γ ⊢ ρ : Δ
--   ---------------------- Γ ⊢ u :# ρ : Δ, A </tt>
(:#) :: a -> Substitution' a -> Substitution' a

-- | Strengthening substitution. First argument is
--   <tt><b>IMPOSSIBLE</b></tt>. In <tt>'Strengthen err n ρ</tt> the number
--   <tt>n</tt> must be non-negative. This substitution should only be
--   applied to values <tt>t</tt> for which none of the variables
--   <tt>0</tt> up to <tt>n - 1</tt> are free in <tt>t[ρ]</tt>, and in that
--   case <tt>n</tt> is subtracted from all free de Bruijn indices in
--   <tt>t[ρ]</tt>. Γ ⊢ ρ : Δ |Θ| = n --------------------------- Γ ⊢
--   Strengthen n ρ : Δ, Θ @
Strengthen :: Impossible -> !Int -> Substitution' a -> Substitution' a

-- | Weakening substitution, lifts to an extended context. <tt> Γ ⊢ ρ : Δ
--   ------------------- Γ, Ψ ⊢ Wk |Ψ| ρ : Δ </tt>
Wk :: !Int -> Substitution' a -> Substitution' a

-- | Lifting substitution. Use this to go under a binder. <tt>Lift 1 ρ ==
--   var 0 :# Wk 1 ρ</tt>. <tt> Γ ⊢ ρ : Δ ------------------------- Γ, Ψρ ⊢
--   Lift |Ψ| ρ : Δ, Ψ </tt>
Lift :: !Int -> Substitution' a -> Substitution' a
infixr 4 :#
type Substitution = Substitution' Term
instance Functor TelV
instance Show a => Show (TelV a)
instance (TermSubst a, Eq a) => Eq (TelV a)
instance (TermSubst a, Ord a) => Ord (TelV a)
instance Eq Substitution
instance Ord Substitution
instance Eq Sort
instance Ord Sort
instance Eq Level
instance Ord Level
instance Eq PlusLevel
instance Eq NotBlocked
instance Eq t => Eq (Blocked t)
instance Eq CandidateKind
instance Eq Candidate
instance Ord CandidateKind
instance Ord Candidate
instance (Subst a, Eq a) => Eq (Tele a)
instance (Subst a, Ord a) => Ord (Tele a)
instance Eq Section
instance Ord a => Ord (Dom a)
instance TeleNoAbs ListTel
instance TeleNoAbs Telescope
instance Apply Term
instance Apply BraveTerm
instance Apply Sort
instance TermSubst a => Apply (Tele a)
instance Apply Definition
instance Apply RewriteRule
instance Apply [Occurrence]
instance Apply [Polarity]
instance Apply NumGeneralizableArgs
instance Apply [NamedArg (Pattern' a)]
instance Apply Projection
instance Apply ProjLams
instance Apply Defn
instance Apply PrimFun
instance Apply Clause
instance Apply CompiledClauses
instance Apply ExtLamInfo
instance Apply System
instance Apply a => Apply (WithArity a)
instance Apply a => Apply (Case a)
instance Apply FunctionInverse
instance Apply DisplayTerm
instance Apply t => Apply [t]
instance Apply t => Apply (Blocked t)
instance Apply t => Apply (Maybe t)
instance Apply t => Apply (Maybe t)
instance Apply v => Apply (Map k v)
instance Apply v => Apply (HashMap k v)
instance (Apply a, Apply b) => Apply (a, b)
instance (Apply a, Apply b, Apply c) => Apply (a, b, c)
instance DoDrop a => Apply (Drop a)
instance DoDrop a => Abstract (Drop a)
instance Apply Permutation
instance Abstract Permutation
instance Abstract Term
instance Abstract Type
instance Abstract Sort
instance Abstract Telescope
instance Abstract Definition
instance Abstract RewriteRule
instance Abstract [Occurrence]
instance Abstract [Polarity]
instance Abstract NumGeneralizableArgs
instance Abstract Projection
instance Abstract ProjLams
instance Abstract System
instance Abstract Defn
instance Abstract PrimFun
instance Abstract Clause
instance Abstract CompiledClauses
instance Abstract a => Abstract (WithArity a)
instance Abstract a => Abstract (Case a)
instance Abstract FunctionInverse
instance Abstract t => Abstract [t]
instance Abstract t => Abstract (Maybe t)
instance Abstract v => Abstract (Map k v)
instance Abstract v => Abstract (HashMap k v)
instance EndoSubst a => Subst (Substitution' a)
instance Subst Term
instance Subst BraveTerm
instance (Coercible a Term, Subst a, Subst b, SubstArg a ~ SubstArg b) => Subst (Type'' a b)
instance (Coercible a Term, Subst a) => Subst (Sort' a)
instance Subst a => Subst (Level' a)
instance Subst a => Subst (PlusLevel' a)
instance Subst Name
instance Subst ConPatternInfo
instance Subst Pattern
instance Subst ProblemEq
instance DeBruijn BraveTerm
instance DeBruijn NLPat
instance Subst NLPat
instance Subst NLPType
instance Subst NLPSort
instance Subst RewriteRule
instance Subst a => Subst (Blocked a)
instance Subst DisplayForm
instance Subst DisplayTerm
instance Subst a => Subst (Tele a)
instance Subst Constraint
instance Subst CompareAs
instance Subst a => Subst (Elim' a)
instance Subst a => Subst (Abs a)
instance Subst a => Subst (Arg a)
instance Subst a => Subst (Named name a)
instance (Subst a, Subst b, SubstArg a ~ SubstArg b) => Subst (Dom' a b)
instance Subst LetBinding
instance Subst a => Subst (Maybe a)
instance Subst a => Subst [a]
instance (Ord k, Subst a) => Subst (Map k a)
instance Subst a => Subst (WithHiding a)
instance Subst ()
instance (Subst a, Subst b, SubstArg a ~ SubstArg b) => Subst (a, b)
instance (Subst a, Subst b, Subst c, SubstArg a ~ SubstArg b, SubstArg b ~ SubstArg c) => Subst (a, b, c)
instance (Subst a, Subst b, Subst c, Subst d, SubstArg a ~ SubstArg b, SubstArg b ~ SubstArg c, SubstArg c ~ SubstArg d) => Subst (a, b, c, d)
instance Subst Candidate
instance Subst EqualityView
instance Subst EqualityTypeData
instance DeBruijn a => DeBruijn (Pattern' a)
instance Subst DeBruijnPattern
instance Subst Range
instance Ord PlusLevel
instance Eq a => Eq (Type' a)
instance Ord a => Ord (Type' a)
instance Eq Term
instance Eq a => Eq (Pattern' a)
instance Ord Term
instance (Subst a, Eq a) => Eq (Abs a)
instance (Subst a, Ord a) => Ord (Abs a)
instance (Subst a, Eq a) => Eq (Elim' a)
instance (Subst a, Ord a) => Ord (Elim' a)

module Agda.Compiler.Treeless.Subst
newtype UnderLambda
UnderLambda :: Any -> UnderLambda
newtype SeqArg
SeqArg :: All -> SeqArg
data Occurs
Occurs :: Int -> UnderLambda -> SeqArg -> Occurs
once :: Occurs
inSeq :: Occurs -> Occurs
underLambda :: Occurs -> Occurs
class HasFree a
freeVars :: HasFree a => a -> Map Int Occurs
freeIn :: HasFree a => Int -> a -> Bool
occursIn :: HasFree a => Int -> a -> Occurs
data Binder a
Binder :: Int -> a -> Binder a
newtype InSeq a
InSeq :: a -> InSeq a

-- | Strenghtening.
tryStrengthen :: (HasFree a, Subst a) => Int -> a -> Maybe a
instance GHC.Base.Monoid Agda.Compiler.Treeless.Subst.UnderLambda
instance GHC.Base.Semigroup Agda.Compiler.Treeless.Subst.UnderLambda
instance GHC.Show.Show Agda.Compiler.Treeless.Subst.UnderLambda
instance GHC.Classes.Ord Agda.Compiler.Treeless.Subst.UnderLambda
instance GHC.Classes.Eq Agda.Compiler.Treeless.Subst.UnderLambda
instance GHC.Base.Monoid Agda.Compiler.Treeless.Subst.SeqArg
instance GHC.Base.Semigroup Agda.Compiler.Treeless.Subst.SeqArg
instance GHC.Show.Show Agda.Compiler.Treeless.Subst.SeqArg
instance GHC.Classes.Ord Agda.Compiler.Treeless.Subst.SeqArg
instance GHC.Classes.Eq Agda.Compiler.Treeless.Subst.SeqArg
instance GHC.Show.Show Agda.Compiler.Treeless.Subst.Occurs
instance GHC.Classes.Ord Agda.Compiler.Treeless.Subst.Occurs
instance GHC.Classes.Eq Agda.Compiler.Treeless.Subst.Occurs
instance Agda.Compiler.Treeless.Subst.HasFree a => Agda.Compiler.Treeless.Subst.HasFree (Agda.Compiler.Treeless.Subst.InSeq a)
instance Agda.Compiler.Treeless.Subst.HasFree Agda.Syntax.Treeless.TTerm
instance Agda.Compiler.Treeless.Subst.HasFree a => Agda.Compiler.Treeless.Subst.HasFree (Agda.Compiler.Treeless.Subst.Binder a)
instance Agda.Compiler.Treeless.Subst.HasFree Agda.Syntax.Treeless.TAlt
instance Agda.Compiler.Treeless.Subst.HasFree GHC.Types.Int
instance Agda.Compiler.Treeless.Subst.HasFree a => Agda.Compiler.Treeless.Subst.HasFree [a]
instance (Agda.Compiler.Treeless.Subst.HasFree a, Agda.Compiler.Treeless.Subst.HasFree b) => Agda.Compiler.Treeless.Subst.HasFree (a, b)
instance GHC.Base.Semigroup Agda.Compiler.Treeless.Subst.Occurs
instance GHC.Base.Monoid Agda.Compiler.Treeless.Subst.Occurs
instance Agda.TypeChecking.Substitute.DeBruijn.DeBruijn Agda.Syntax.Treeless.TTerm
instance Agda.TypeChecking.Substitute.Class.Subst Agda.Syntax.Treeless.TTerm
instance Agda.TypeChecking.Substitute.Class.Subst Agda.Syntax.Treeless.TAlt

module Agda.Compiler.Treeless.Pretty
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Treeless.Compiled
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Treeless.TTerm

module Agda.Compiler.Treeless.Compare
equalTerms :: TTerm -> TTerm -> Bool

module Agda.Compiler.Treeless.Uncase
caseToSeq :: Monad m => TTerm -> m TTerm

module Agda.TypeChecking.Serialise.Base

-- | Constructor tag (maybe omitted) and argument indices.
data Node
Empty :: Node
Cons :: !Int32 -> !Node -> Node

-- | Association lists mapping TypeRep fingerprints to values. In some
--   cases values with different types have the same serialized
--   representation. This structure disambiguates them.
data MemoEntry
MEEmpty :: MemoEntry
MECons :: {-# UNPACK #-} !Fingerprint -> !Any -> !MemoEntry -> MemoEntry
fingerprintNoinline :: TypeRep -> Fingerprint
lookupME :: forall a b. Proxy a -> Fingerprint -> MemoEntry -> (a -> b) -> b -> b

-- | Structure providing fresh identifiers for hash map and counting hash
--   map hits (i.e. when no fresh identifier required).
newtype FreshAndReuse
FreshAndReuse :: Int32 -> FreshAndReuse

-- | Number of hash map misses.
[farFresh] :: FreshAndReuse -> Int32
farEmpty :: FreshAndReuse
lensFresh :: Lens' FreshAndReuse Int32

-- | Two <a>QName</a>s are equal if their <tt>QNameId</tt> is equal.
type QNameId = [NameId]

-- | Computing a qualified names composed ID.
qnameId :: QName -> QNameId

-- | State of the the encoder.
data Dict
Dict :: !HashTable Node Int32 -> !HashTable String Int32 -> !HashTable Text Int32 -> !HashTable Text Int32 -> !HashTable Integer Int32 -> !HashTable Double Int32 -> !HashTable (Ptr Term) Int32 -> !HashTable NameId Int32 -> !HashTable QNameId Int32 -> !IORef FreshAndReuse -> !IORef FreshAndReuse -> !IORef FreshAndReuse -> !IORef FreshAndReuse -> !IORef FreshAndReuse -> !IORef FreshAndReuse -> !IORef FreshAndReuse -> !IORef FreshAndReuse -> !IORef FreshAndReuse -> !HashTable String Int -> !Bool -> Dict

-- | Written to interface file.
[nodeD] :: Dict -> !HashTable Node Int32

-- | Written to interface file.
[stringD] :: Dict -> !HashTable String Int32

-- | Written to interface file.
[lTextD] :: Dict -> !HashTable Text Int32

-- | Written to interface file.
[sTextD] :: Dict -> !HashTable Text Int32

-- | Written to interface file.
[integerD] :: Dict -> !HashTable Integer Int32

-- | Written to interface file. Dicitionaries which are not serialized, but
--   provide short cuts to speed up serialization:
[doubleD] :: Dict -> !HashTable Double Int32

-- | Not written to interface file. Andreas, Makoto, AIM XXI Memoizing
--   A.Name does not buy us much if we already memoize A.QName.
[termD] :: Dict -> !HashTable (Ptr Term) Int32

-- | Not written to interface file.
[nameD] :: Dict -> !HashTable NameId Int32

-- | Not written to interface file. Fresh UIDs and reuse statistics:
[qnameD] :: Dict -> !HashTable QNameId Int32
[nodeC] :: Dict -> !IORef FreshAndReuse
[stringC] :: Dict -> !IORef FreshAndReuse
[lTextC] :: Dict -> !IORef FreshAndReuse
[sTextC] :: Dict -> !IORef FreshAndReuse
[integerC] :: Dict -> !IORef FreshAndReuse
[doubleC] :: Dict -> !IORef FreshAndReuse
[termC] :: Dict -> !IORef FreshAndReuse
[nameC] :: Dict -> !IORef FreshAndReuse
[qnameC] :: Dict -> !IORef FreshAndReuse
[stats] :: Dict -> !HashTable String Int

-- | If <tt>True</tt> collect in <tt>stats</tt> the quantities of calls to
--   <tt>icode</tt> for each <tt>Typeable a</tt>.
[collectStats] :: Dict -> !Bool

-- | Creates an empty dictionary.
emptyDict :: Bool -> IO Dict

-- | Univeral memo structure, to introduce sharing during decoding
type Memo = IOArray Int32 MemoEntry

-- | State of the decoder.
data St
St :: !Array Int32 [Int32] -> !Array Int32 String -> !Array Int32 Text -> !Array Int32 Text -> !Array Int32 Integer -> !Array Int32 Double -> !Memo -> !ModuleToSource -> ![AbsolutePath] -> St

-- | Obtained from interface file.
[nodeE] :: St -> !Array Int32 [Int32]

-- | Obtained from interface file.
[stringE] :: St -> !Array Int32 String

-- | Obtained from interface file.
[lTextE] :: St -> !Array Int32 Text

-- | Obtained from interface file.
[sTextE] :: St -> !Array Int32 Text

-- | Obtained from interface file.
[integerE] :: St -> !Array Int32 Integer

-- | Obtained from interface file.
[doubleE] :: St -> !Array Int32 Double

-- | Created and modified by decoder. Used to introduce sharing while
--   deserializing objects.
[nodeMemo] :: St -> !Memo

-- | Maps module names to file names. Constructed by the decoder.
[modFile] :: St -> !ModuleToSource

-- | The include directories.
[includes] :: St -> ![AbsolutePath]

-- | Monad used by the encoder.
type S a = ReaderT Dict IO a

-- | Monad used by the decoder.
--   
--   <tt>TCM</tt> is not used because the associated overheads would make
--   decoding slower.
type R = StateT St IO

-- | Throws an error which is suitable when the data stream is malformed.
malformed :: R a
class Typeable a => EmbPrj a
icode :: EmbPrj a => a -> S Int32
icod_ :: EmbPrj a => a -> S Int32
value :: EmbPrj a => Int32 -> R a
value :: (EmbPrj a, Enum a, Bounded a) => Int32 -> R a
icod_ :: (EmbPrj a, Enum a, Bounded a) => a -> S Int32

-- | The actual logic of <a>tickICode</a> is cold code, so it's
--   out-of-line, to decrease code size and avoid cache pollution.
goTickIcode :: forall a. Typeable a => Proxy a -> S ()

-- | Increase entry for <tt>a</tt> in <a>stats</a>.
tickICode :: forall a. Typeable a => a -> S ()

-- | Data.Binary.runGetState is deprecated in favour of runGetIncremental.
--   Reimplementing it in terms of the new function. The new Decoder type
--   contains strict byte strings so we need to be careful not to feed the
--   entire lazy byte string to the decoder at once.
runGetState :: Get a -> ByteString -> ByteOffset -> (a, ByteString, ByteOffset)
icodeX :: (Eq k, Hashable k) => (Dict -> HashTable k Int32) -> (Dict -> IORef FreshAndReuse) -> k -> S Int32
icodeInteger :: Integer -> S Int32
icodeDouble :: Double -> S Int32
icodeString :: String -> S Int32
icodeNode :: Node -> S Int32

-- | <tt>icode</tt> only if thing has not seen before.
icodeMemo :: (Ord a, Hashable a) => (Dict -> HashTable a Int32) -> (Dict -> IORef FreshAndReuse) -> a -> S Int32 -> S Int32

-- | <tt>vcase value ix</tt> decodes thing represented by <tt>ix ::
--   Int32</tt> via the <tt>valu</tt> function and stores it in
--   <a>nodeMemo</a>. If <tt>ix</tt> is present in <a>nodeMemo</a>,
--   <tt>valu</tt> is not used, but the thing is read from <a>nodeMemo</a>
--   instead.
vcase :: forall a. EmbPrj a => ([Int32] -> R a) -> Int32 -> R a

-- | <tt>icodeArgs proxy (a1, ..., an)</tt> maps <tt>icode</tt> over
--   <tt>a1</tt>, ..., <tt>an</tt> and returns the corresponding list of
--   <tt>Int32</tt>.
class ICODE t b
icodeArgs :: (ICODE t b, IsBase t ~ b) => All EmbPrj (Domains t) => Proxy t -> StrictProducts (Domains t) -> S Node

-- | <tt>icodeN tag t a1 ... an</tt> serialises the arguments <tt>a1</tt>,
--   ..., <tt>an</tt> of the constructor <tt>t</tt> together with a tag
--   <tt>tag</tt> picked to disambiguate between different constructors. It
--   corresponds to <tt>icodeNode . (tag :) =&lt;&lt; mapM icode [a1, ...,
--   an]</tt>
icodeN :: forall t. ICODE t (IsBase t) => StrictCurrying (Domains t) (S Int32) => All EmbPrj (Domains t) => Int32 -> t -> Arrows (Domains t) (S Int32)

-- | <tt>icodeN'</tt> is the same as <tt>icodeN</tt> except that there is
--   no tag
icodeN' :: forall t. ICODE t (IsBase t) => StrictCurrying (Domains t) (S Int32) => All EmbPrj (Domains t) => t -> Arrows (Domains t) (S Int32)
class VALU t b
valuN' :: (VALU t b, b ~ IsBase t) => All EmbPrj (Domains t) => t -> StrictProducts (Constant Int32 (Domains t)) -> R (CoDomain t)
valueArgs :: (VALU t b, b ~ IsBase t) => All EmbPrj (CoDomain t ': Domains t) => Proxy t -> [Int32] -> Maybe (StrictProducts (Constant Int32 (Domains t)))
valuN :: forall t. VALU t (IsBase t) => StrictCurrying (Constant Int32 (Domains t)) (R (CoDomain t)) => All EmbPrj (Domains t) => t -> Arrows (Constant Int32 (Domains t)) (R (CoDomain t))
valueN :: forall t. VALU t (IsBase t) => All EmbPrj (CoDomain t ': Domains t) => t -> Int32 -> R (CoDomain t)
instance GHC.Classes.Eq Agda.TypeChecking.Serialise.Base.Node
instance Agda.TypeChecking.Serialise.Base.VALU t 'GHC.Types.True
instance Agda.TypeChecking.Serialise.Base.VALU t (Agda.Utils.TypeLevel.IsBase t) => Agda.TypeChecking.Serialise.Base.VALU (a -> t) 'GHC.Types.False
instance (Agda.Utils.TypeLevel.IsBase t GHC.Types.~ 'GHC.Types.True) => Agda.TypeChecking.Serialise.Base.ICODE t 'GHC.Types.True
instance Agda.TypeChecking.Serialise.Base.ICODE t (Agda.Utils.TypeLevel.IsBase t) => Agda.TypeChecking.Serialise.Base.ICODE (a -> t) 'GHC.Types.False
instance Data.Hashable.Class.Hashable Agda.TypeChecking.Serialise.Base.Node
instance Data.Binary.Class.Binary Agda.TypeChecking.Serialise.Base.Node

module Agda.TypeChecking.Monad.Imports
addImport :: TopLevelModuleName -> TCM ()
addImportCycleCheck :: TopLevelModuleName -> TCM a -> TCM a

-- | Assumes that the first module in the import path is the module we are
--   worried about.
checkForImportCycle :: TCM ()
dropDecodedModule :: TopLevelModuleName -> TCM ()
getDecodedModule :: TopLevelModuleName -> TCM (Maybe ModuleInfo)
getDecodedModules :: TCM DecodedModules
getImportPath :: TCM [TopLevelModuleName]
getPrettyVisitedModules :: ReadTCState m => m Doc
getVisitedModule :: ReadTCState m => TopLevelModuleName -> m (Maybe ModuleInfo)
getVisitedModules :: ReadTCState m => m VisitedModules
setDecodedModules :: DecodedModules -> TCM ()
setVisitedModules :: VisitedModules -> TCM ()
storeDecodedModule :: ModuleInfo -> TCM ()
visitModule :: ModuleInfo -> TCM ()
withImportPath :: [TopLevelModuleName] -> TCM a -> TCM a

module Agda.TypeChecking.Monad.Env

-- | Get the name of the current module, if any.
currentModule :: MonadTCEnv m => m ModuleName

-- | Set the name of the current module.
withCurrentModule :: MonadTCEnv m => ModuleName -> m a -> m a

-- | Get the path of the currently checked file
getCurrentPath :: MonadTCEnv m => m AbsolutePath

-- | Get the number of variables bound by anonymous modules.
getAnonymousVariables :: MonadTCEnv m => ModuleName -> m Nat

-- | Add variables bound by an anonymous module.
withAnonymousModule :: ModuleName -> Nat -> TCM a -> TCM a

-- | Set the current environment to the given
withEnv :: MonadTCEnv m => TCEnv -> m a -> m a

-- | Get the current environment
getEnv :: TCM TCEnv

-- | Set highlighting level
withHighlightingLevel :: HighlightingLevel -> TCM a -> TCM a

-- | Restore setting for <a>ExpandLast</a> to default.
doExpandLast :: TCM a -> TCM a
dontExpandLast :: TCM a -> TCM a
reallyDontExpandLast :: TCM a -> TCM a

-- | If the reduced did a proper match (constructor or literal pattern),
--   then record this as simplification step.
performedSimplification :: MonadTCEnv m => m a -> m a
performedSimplification' :: MonadTCEnv m => Simplification -> m a -> m a
getSimplification :: MonadTCEnv m => m Simplification

-- | Lens for <a>AllowedReductions</a>.
updateAllowedReductions :: (AllowedReductions -> AllowedReductions) -> TCEnv -> TCEnv
modifyAllowedReductions :: MonadTCEnv m => (AllowedReductions -> AllowedReductions) -> m a -> m a
putAllowedReductions :: MonadTCEnv m => AllowedReductions -> m a -> m a

-- | Reduce <tt>Def f vs</tt> only if <tt>f</tt> is a projection.
onlyReduceProjections :: MonadTCEnv m => m a -> m a

-- | Allow all reductions except for non-terminating functions (default).
allowAllReductions :: MonadTCEnv m => m a -> m a

-- | Allow all reductions including non-terminating functions.
allowNonTerminatingReductions :: MonadTCEnv m => m a -> m a

-- | Allow all reductions when reducing types. Otherwise only allow inlined
--   functions to be unfolded.
onlyReduceTypes :: MonadTCEnv m => m a -> m a

-- | Update allowed reductions when working on types
typeLevelReductions :: MonadTCEnv m => m a -> m a
insideDotPattern :: TCM a -> TCM a
isInsideDotPattern :: TCM Bool

-- | Don't use call-by-need evaluation for the given computation.
callByName :: TCM a -> TCM a

-- | Don't fold let bindings when printing. This is a bit crude since it
--   disables any folding of let bindings at all. In many cases it's better
--   to use <tt>removeLetBinding</tt> before printing to drop the let
--   bindings that should not be folded.
dontFoldLetBindings :: MonadTCEnv m => m a -> m a

module Agda.TypeChecking.Monad.Builtin
class (Functor m, Applicative m, MonadFail m) => HasBuiltins m
getBuiltinThing :: HasBuiltins m => SomeBuiltin -> m (Maybe (Builtin PrimFun))
getBuiltinThing :: (HasBuiltins m, MonadTrans t, HasBuiltins n, t n ~ m) => SomeBuiltin -> m (Maybe (Builtin PrimFun))

-- | The trivial implementation of <a>HasBuiltins</a>, using a constant
--   <a>TCState</a>.
--   
--   This may be used instead of <a>TCMT</a>/<a>ReduceM</a> where builtins
--   must be accessed in a pure context.
newtype BuiltinAccess a
BuiltinAccess :: (TCState -> a) -> BuiltinAccess a
[unBuiltinAccess] :: BuiltinAccess a -> TCState -> a

-- | The coinductive primitives.
data CoinductionKit
CoinductionKit :: QName -> QName -> QName -> CoinductionKit
[nameOfInf] :: CoinductionKit -> QName
[nameOfSharp] :: CoinductionKit -> QName
[nameOfFlat] :: CoinductionKit -> QName

-- | Sort primitives.
data SortKit
SortKit :: (UnivSize -> Univ -> QName) -> (QName -> Maybe (UnivSize, Univ)) -> SortKit
[nameOfUniv] :: SortKit -> UnivSize -> Univ -> QName
[isNameOfUniv] :: SortKit -> QName -> Maybe (UnivSize, Univ)

-- | Revert the <a>EqualityView</a>.
--   
--   Postcondition: type is reduced.
class EqualityUnview a
equalityUnview :: EqualityUnview a => a -> Type
getBuiltinName' :: HasBuiltins m => BuiltinId -> m (Maybe QName)

-- | Rewrite a literal to constructor form if possible.
constructorForm :: HasBuiltins m => Term -> m Term
getName' :: (HasBuiltins m, IsBuiltin a) => a -> m (Maybe QName)
getBuiltin' :: HasBuiltins m => BuiltinId -> m (Maybe Term)
primConId :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIdElim :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIMin :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIMax :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primINeg :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primPartial :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primPartialP :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSubOut :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primGlue :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFaceForall :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primHComp :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNatPlus :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNatMinus :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNatTimes :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNatDivSucAux :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNatModSucAux :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNatEquality :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNatLess :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primLevelZero :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primLevelSuc :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primLevelMax :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primLockUniv :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term

-- | Run a <a>BuiltinAccess</a> monad.
runBuiltinAccess :: TCState -> BuiltinAccess a -> a
litType :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => Literal -> m Type
primZero :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSuc :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNat :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primWord64 :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFloat :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primChar :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primString :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primQName :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaMeta :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
setBuiltinThings :: BuiltinThings PrimFun -> TCM ()
bindBuiltinName :: BuiltinId -> Term -> TCM ()
bindPrimitive :: PrimitiveId -> PrimFun -> TCM ()

-- | Add one (more) relation symbol to the rewrite relations.
bindBuiltinRewriteRelation :: QName -> TCM ()

-- | Get the currently registered rewrite relation symbols.
getBuiltinRewriteRelations :: (HasBuiltins m, MonadTCError m) => m (Set QName)

-- | Get the currently registered rewrite relation symbols, if any.
getBuiltinRewriteRelations' :: HasBuiltins m => m (Maybe (Set QName))
getBuiltin :: (HasBuiltins m, MonadTCError m) => BuiltinId -> m Term
getPrimitive' :: HasBuiltins m => PrimitiveId -> m (Maybe PrimFun)
getPrimitive :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => PrimitiveId -> m PrimFun
getPrimitiveTerm :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => PrimitiveId -> m Term
getPrimitiveTerm' :: HasBuiltins m => PrimitiveId -> m (Maybe Term)
getPrimitiveName' :: HasBuiltins m => PrimitiveId -> m (Maybe QName)
getTerm' :: (HasBuiltins m, IsBuiltin a) => a -> m (Maybe Term)

-- | <tt>getTerm use name</tt> looks up <tt>name</tt> as a primitive or
--   builtin, and throws an error otherwise. The <tt>use</tt> argument
--   describes how the name is used for the sake of the error message.
getTerm :: (HasBuiltins m, IsBuiltin a) => String -> a -> m Term
constructorForm' :: Applicative m => m Term -> m Term -> Term -> m Term
primInteger :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIntegerPos :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIntegerNegSuc :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primUnit :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primUnitUnit :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primBool :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primTrue :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFalse :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSigma :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primList :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNil :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primCons :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIO :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primMaybe :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNothing :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primJust :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primPath :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primPathP :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIntervalUniv :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primInterval :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIZero :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIOne :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIsOne :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primItIsOne :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIsOne1 :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIsOne2 :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIsOneEmpty :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSub :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSubIn :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primTrans :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primId :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primEquiv :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primEquivFun :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primEquivProof :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primTranspProof :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
prim_glue :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
prim_unglue :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
prim_glueU :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
prim_unglueU :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSizeUniv :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSize :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSizeLt :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSizeSuc :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSizeInf :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSizeMax :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primInf :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSharp :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFlat :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primEquality :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primRefl :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primLevel :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primLevelUniv :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primProp :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSet :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primStrictSet :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primPropOmega :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSetOmega :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSSetOmega :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFromNat :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFromNeg :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFromString :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primArgInfo :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primArgArgInfo :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primArg :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primArgArg :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAbs :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAbsAbs :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTerm :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermVar :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermLam :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermExtLam :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermDef :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermCon :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermPi :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermSort :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermLit :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermUnsupported :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermMeta :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaErrorPart :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaErrorPartString :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaErrorPartTerm :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaErrorPartPatt :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaErrorPartName :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primHiding :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primHidden :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primInstance :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primVisible :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primRelevance :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primRelevant :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIrrelevant :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primQuantity :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primQuantity0 :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primQuantityω :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primModality :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primModalityConstructor :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAssoc :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAssocLeft :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAssocRight :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAssocNon :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primPrecedence :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primPrecRelated :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primPrecUnrelated :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFixity :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFixityFixity :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaLiteral :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaLitNat :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaLitWord64 :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaLitFloat :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaLitString :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaLitChar :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaLitQName :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaLitMeta :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaSort :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaSortSet :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaSortLit :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaSortProp :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaSortPropLit :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaSortInf :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaSortUnsupported :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaDefinition :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaDefinitionFunDef :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaDefinitionDataDef :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaDefinitionRecordDef :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaDefinitionPostulate :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaDefinitionPrimitive :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaDefinitionDataConstructor :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaClause :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaClauseClause :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaClauseAbsurd :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaPattern :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaPatCon :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaPatVar :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaPatDot :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaPatLit :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaPatProj :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaPatAbsurd :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaBlocker :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaBlockerAny :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaBlockerAll :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaBlockerMeta :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCM :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMReturn :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMBind :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMUnify :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMTypeError :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMInferType :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMCheckType :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMNormalise :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMReduce :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMCatchError :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMGetContext :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMExtendContext :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMInContext :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMFreshName :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMDeclareDef :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMDeclarePostulate :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMDeclareData :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMDefineData :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMDefineFun :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMGetType :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMGetDefinition :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMQuoteTerm :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMUnquoteTerm :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMQuoteOmegaTerm :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMCommit :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMIsMacro :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMBlock :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMFormatErrorParts :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMDebugPrint :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMWithNormalisation :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMWithReconstructed :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMWithExpandLast :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMWithReduceDefs :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMAskNormalisation :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMAskReconstructed :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMAskExpandLast :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMAskReduceDefs :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMNoConstraints :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMWorkOnTypes :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMRunSpeculative :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMExec :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMGetInstances :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMSolveInstances :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMPragmaForeign :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMPragmaCompile :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term

-- | Tries to build a <a>CoinductionKit</a>.
coinductionKit' :: TCM CoinductionKit
coinductionKit :: TCM (Maybe CoinductionKit)
mkSortKit :: QName -> QName -> QName -> QName -> QName -> QName -> SortKit

-- | Compute a <a>SortKit</a> in an environment that supports failures.
--   
--   When <tt>optLoadPrimitives</tt> is set to <a>False</a>, <a>sortKit</a>
--   is a fallible operation, so for the uses of <a>sortKit</a> in fallible
--   contexts (e.g. <a>TCMT</a>), we report a type error rather than
--   exploding.
sortKit :: (HasBuiltins m, MonadTCError m, HasOptions m) => m SortKit

-- | Compute a <a>SortKit</a> in contexts that do not support failure (e.g.
--   <tt>Reify</tt>). This should only be used when we are sure that the
--   primitive sorts have been bound, i.e. because it is "after" type
--   checking.
infallibleSortKit :: HasBuiltins m => m SortKit
getPrimName :: Term -> QName
isPrimitive :: HasBuiltins m => PrimitiveId -> QName -> m Bool
intervalSort :: Sort
intervalView' :: HasBuiltins m => m (Term -> IntervalView)
intervalView :: HasBuiltins m => Term -> m IntervalView
intervalUnview :: HasBuiltins m => IntervalView -> m Term
intervalUnview' :: HasBuiltins m => m (IntervalView -> Term)

-- | Check whether the type is actually an path (lhs ≡ rhs) and extract
--   lhs, rhs, and their type.
--   
--   Precondition: type is reduced.
pathView :: HasBuiltins m => Type -> m PathView
pathView' :: HasBuiltins m => m (Type -> PathView)

-- | Non dependent Path
idViewAsPath :: HasBuiltins m => Type -> m PathView
boldPathView :: Type -> PathView

-- | Revert the <a>PathView</a>.
--   
--   Postcondition: type is reduced.
pathUnview :: PathView -> Type
conidView' :: HasBuiltins m => m (Term -> Term -> Maybe (Arg Term, Arg Term))

-- | Get the name of the equality type.
primEqualityName :: TCM QName

-- | Check whether the type is actually an equality (lhs ≡ rhs) and extract
--   lhs, rhs, and their type.
--   
--   Precondition: type is reduced.
equalityView :: Type -> TCM EqualityView

-- | Primitives with typechecking constrants.
constrainedPrims :: [PrimitiveId]
getNameOfConstrained :: HasBuiltins m => PrimitiveId -> m (Maybe QName)
instance GHC.Base.Monad Agda.TypeChecking.Monad.Builtin.BuiltinAccess
instance GHC.Base.Applicative Agda.TypeChecking.Monad.Builtin.BuiltinAccess
instance GHC.Base.Functor Agda.TypeChecking.Monad.Builtin.BuiltinAccess
instance Agda.TypeChecking.Monad.Builtin.HasBuiltins m => Agda.TypeChecking.Monad.Builtin.HasBuiltins (Agda.TypeChecking.Monad.Base.BlockT m)
instance Agda.TypeChecking.Monad.Builtin.EqualityUnview Agda.Syntax.Internal.EqualityView
instance Agda.TypeChecking.Monad.Builtin.EqualityUnview Agda.Syntax.Internal.EqualityTypeData
instance Control.Monad.Fail.MonadFail Agda.TypeChecking.Monad.Builtin.BuiltinAccess
instance Agda.TypeChecking.Monad.Builtin.HasBuiltins Agda.TypeChecking.Monad.Builtin.BuiltinAccess
instance Agda.TypeChecking.Monad.Builtin.HasBuiltins m => Agda.TypeChecking.Monad.Builtin.HasBuiltins (Agda.Utils.Update.ChangeT m)
instance Agda.TypeChecking.Monad.Builtin.HasBuiltins m => Agda.TypeChecking.Monad.Builtin.HasBuiltins (Control.Monad.Trans.Except.ExceptT e m)
instance Agda.TypeChecking.Monad.Builtin.HasBuiltins m => Agda.TypeChecking.Monad.Builtin.HasBuiltins (Control.Monad.Trans.Identity.IdentityT m)
instance Agda.TypeChecking.Monad.Builtin.HasBuiltins m => Agda.TypeChecking.Monad.Builtin.HasBuiltins (Agda.Utils.ListT.ListT m)
instance Agda.TypeChecking.Monad.Builtin.HasBuiltins m => Agda.TypeChecking.Monad.Builtin.HasBuiltins (Control.Monad.Trans.Maybe.MaybeT m)
instance Agda.TypeChecking.Monad.Builtin.HasBuiltins m => Agda.TypeChecking.Monad.Builtin.HasBuiltins (Control.Monad.Trans.Reader.ReaderT e m)
instance Agda.TypeChecking.Monad.Builtin.HasBuiltins m => Agda.TypeChecking.Monad.Builtin.HasBuiltins (Control.Monad.Trans.State.Lazy.StateT s m)
instance (Agda.TypeChecking.Monad.Builtin.HasBuiltins m, GHC.Base.Monoid w) => Agda.TypeChecking.Monad.Builtin.HasBuiltins (Control.Monad.Trans.Writer.Lazy.WriterT w m)
instance Control.Monad.IO.Class.MonadIO m => Agda.TypeChecking.Monad.Builtin.HasBuiltins (Agda.TypeChecking.Monad.Base.TCMT m)


-- | Logic for deciding which functions should be automatically inlined.
module Agda.TypeChecking.Inlining

-- | Mark a definition to be inlined if it satisfies the inlining
--   criterion.
autoInline :: Defn -> TCM Defn

module Agda.TypeChecking.Monad.Debug
class (Functor m, Applicative m, Monad m) => MonadDebug m
formatDebugMessage :: MonadDebug m => VerboseKey -> VerboseLevel -> TCM Doc -> m String
traceDebugMessage :: MonadDebug m => VerboseKey -> VerboseLevel -> String -> m a -> m a

-- | Print brackets around debug messages issued by a computation.
verboseBracket :: MonadDebug m => VerboseKey -> VerboseLevel -> String -> m a -> m a
getVerbosity :: MonadDebug m => m Verbosity
getProfileOptions :: MonadDebug m => m ProfileOptions

-- | Check whether we are currently debug printing.
isDebugPrinting :: MonadDebug m => m Bool

-- | Flag in a computation that we are currently debug printing.
nowDebugPrinting :: MonadDebug m => m a -> m a
formatDebugMessage :: (MonadDebug m, MonadTrans t, MonadDebug n, m ~ t n) => VerboseKey -> VerboseLevel -> TCM Doc -> m String
traceDebugMessage :: (MonadDebug m, MonadTransControl t, MonadDebug n, m ~ t n) => VerboseKey -> VerboseLevel -> String -> m a -> m a

-- | Print brackets around debug messages issued by a computation.
verboseBracket :: (MonadDebug m, MonadTransControl t, MonadDebug n, m ~ t n) => VerboseKey -> VerboseLevel -> String -> m a -> m a
getVerbosity :: (MonadDebug m, MonadTrans t, MonadDebug n, m ~ t n) => m Verbosity
getProfileOptions :: (MonadDebug m, MonadTrans t, MonadDebug n, m ~ t n) => m ProfileOptions

-- | Check whether we are currently debug printing.
isDebugPrinting :: (MonadDebug m, MonadTrans t, MonadDebug n, m ~ t n) => m Bool

-- | Flag in a computation that we are currently debug printing.
nowDebugPrinting :: (MonadDebug m, MonadTransControl t, MonadDebug n, m ~ t n) => m a -> m a

-- | Debug print some lines if the verbosity level for the given
--   <a>VerboseKey</a> is at least <a>VerboseLevel</a>.
--   
--   Note: In the presence of <tt>OverloadedStrings</tt>, just @<tt>
--   reportS key level "Literate string" </tt><tt> gives an </tt>Ambiguous
--   type variable<tt> error in </tt>GHC@. Use the legacy functions
--   <a>reportSLn</a> and <a>reportSDoc</a> instead then.
class ReportS a
reportS :: (ReportS a, MonadDebug m) => VerboseKey -> VerboseLevel -> a -> m ()

-- | Debug print some lines if the verbosity level for the given
--   <a>VerboseKey</a> is at least <a>VerboseLevel</a>.
--   
--   Note: In the presence of <tt>OverloadedStrings</tt>, just @<tt> traceS
--   key level "Literate string" </tt><tt> gives an </tt>Ambiguous type
--   variable<tt> error in </tt>GHC@. Use the legacy functions
--   <a>traceSLn</a> and <a>traceSDoc</a> instead then.
class TraceS a
traceS :: (TraceS a, MonadDebug m) => VerboseKey -> VerboseLevel -> a -> m c -> m c
__IMPOSSIBLE_VERBOSE__ :: (HasCallStack, MonadDebug m) => String -> m a
reportSLn :: MonadDebug m => VerboseKey -> VerboseLevel -> String -> m ()

-- | Conditionally render debug <a>Doc</a> and print it.
reportSDoc :: MonadDebug m => VerboseKey -> VerboseLevel -> TCM Doc -> m ()

-- | Run a computation if a certain verbosity level is activated.
--   
--   Precondition: The level must be non-negative.
verboseS :: MonadDebug m => VerboseKey -> VerboseLevel -> m () -> m ()

-- | Apply a function if a certain verbosity level is activated.
--   
--   Precondition: The level must be non-negative.
applyWhenVerboseS :: MonadDebug m => VerboseKey -> VerboseLevel -> (m a -> m a) -> m a -> m a
defaultGetVerbosity :: HasOptions m => m Verbosity
defaultGetProfileOptions :: HasOptions m => m ProfileOptions
defaultIsDebugPrinting :: MonadTCEnv m => m Bool
defaultNowDebugPrinting :: MonadTCEnv m => m a -> m a

-- | Print a debug message if switched on.
displayDebugMessage :: MonadDebug m => VerboseKey -> VerboseLevel -> String -> m ()

-- | During printing, catch internal errors of kind <a>Impossible</a> and
--   print them.
catchAndPrintImpossible :: (CatchImpossible m, Monad m) => VerboseKey -> VerboseLevel -> m String -> m String

-- | Check whether a certain verbosity level is activated.
--   
--   Precondition: The level must be non-negative.
hasVerbosity :: MonadDebug m => VerboseKey -> VerboseLevel -> m Bool

-- | Conditionally println debug string. Works regardless of the debug
--   flag.
alwaysReportSLn :: MonadDebug m => VerboseKey -> VerboseLevel -> String -> m ()

-- | Debug print the result of a computation.
reportResult :: MonadDebug m => VerboseKey -> VerboseLevel -> (a -> TCM Doc) -> m a -> m a

-- | Conditionally render debug <a>Doc</a> and print it. Works regardless
--   of the debug flag.
alwaysReportSDoc :: MonadDebug m => VerboseKey -> VerboseLevel -> TCM Doc -> m ()
unlessDebugPrinting :: MonadDebug m => m () -> m ()

-- | Conditionally render debug <a>Doc</a>, print it, and then continue.
traceSDoc :: MonadDebug m => VerboseKey -> VerboseLevel -> TCM Doc -> m a -> m a
traceSLn :: MonadDebug m => VerboseKey -> VerboseLevel -> String -> m a -> m a
openVerboseBracket :: MonadDebug m => VerboseKey -> VerboseLevel -> String -> m ()
closeVerboseBracket :: MonadDebug m => VerboseKey -> VerboseLevel -> m ()
closeVerboseBracketException :: MonadDebug m => VerboseKey -> VerboseLevel -> m ()

-- | Check whether a certain verbosity level is activated (exact match).
hasExactVerbosity :: MonadDebug m => VerboseKey -> VerboseLevel -> m Bool

-- | Run a computation if a certain verbosity level is activated (exact
--   match).
whenExactVerbosity :: MonadDebug m => VerboseKey -> VerboseLevel -> m () -> m ()
__CRASH_WHEN__ :: (HasCallStack, MonadTCM m, MonadDebug m) => VerboseKey -> VerboseLevel -> m ()

-- | Check whether a certain profile option is activated.
hasProfileOption :: MonadDebug m => ProfileOption -> m Bool

-- | Run some code when the given profiling option is active.
whenProfile :: MonadDebug m => ProfileOption -> m () -> m ()

-- | <a>Nothing</a> is used if no verbosity options have been given, thus
--   making it possible to handle the default case relatively quickly. Note
--   that <a>Nothing</a> corresponds to a trie with verbosity level 1 for
--   the empty path.
type Verbosity = Maybe (Trie VerboseKeyItem VerboseLevel)
type VerboseKey = String
type VerboseLevel = Int
instance Agda.TypeChecking.Monad.Debug.MonadDebug m => Agda.TypeChecking.Monad.Debug.MonadDebug (Agda.TypeChecking.Monad.Base.BlockT m)
instance Agda.TypeChecking.Monad.Debug.TraceS (Agda.TypeChecking.Monad.Base.TCM Agda.Syntax.Common.Pretty.Doc)
instance Agda.TypeChecking.Monad.Debug.TraceS GHC.Base.String
instance Agda.TypeChecking.Monad.Debug.TraceS [Agda.TypeChecking.Monad.Base.TCM Agda.Syntax.Common.Pretty.Doc]
instance Agda.TypeChecking.Monad.Debug.TraceS [GHC.Base.String]
instance Agda.TypeChecking.Monad.Debug.TraceS [Agda.Syntax.Common.Pretty.Doc]
instance Agda.TypeChecking.Monad.Debug.TraceS Agda.Syntax.Common.Pretty.Doc
instance Agda.TypeChecking.Monad.Debug.ReportS (Agda.TypeChecking.Monad.Base.TCM Agda.Syntax.Common.Pretty.Doc)
instance Agda.TypeChecking.Monad.Debug.ReportS GHC.Base.String
instance Agda.TypeChecking.Monad.Debug.ReportS [Agda.TypeChecking.Monad.Base.TCM Agda.Syntax.Common.Pretty.Doc]
instance Agda.TypeChecking.Monad.Debug.ReportS [GHC.Base.String]
instance Agda.TypeChecking.Monad.Debug.ReportS [Agda.Syntax.Common.Pretty.Doc]
instance Agda.TypeChecking.Monad.Debug.ReportS Agda.Syntax.Common.Pretty.Doc
instance Agda.TypeChecking.Monad.Debug.MonadDebug Agda.TypeChecking.Monad.Base.TCM
instance Agda.TypeChecking.Monad.Debug.MonadDebug m => Agda.TypeChecking.Monad.Debug.MonadDebug (Agda.Utils.Update.ChangeT m)
instance Agda.TypeChecking.Monad.Debug.MonadDebug m => Agda.TypeChecking.Monad.Debug.MonadDebug (Control.Monad.Trans.Except.ExceptT e m)
instance Agda.TypeChecking.Monad.Debug.MonadDebug m => Agda.TypeChecking.Monad.Debug.MonadDebug (Control.Monad.Trans.Maybe.MaybeT m)
instance Agda.TypeChecking.Monad.Debug.MonadDebug m => Agda.TypeChecking.Monad.Debug.MonadDebug (Control.Monad.Trans.Reader.ReaderT r m)
instance Agda.TypeChecking.Monad.Debug.MonadDebug m => Agda.TypeChecking.Monad.Debug.MonadDebug (Control.Monad.Trans.State.Lazy.StateT s m)
instance (Agda.TypeChecking.Monad.Debug.MonadDebug m, GHC.Base.Monoid w) => Agda.TypeChecking.Monad.Debug.MonadDebug (Control.Monad.Trans.Writer.Lazy.WriterT w m)
instance Agda.TypeChecking.Monad.Debug.MonadDebug m => Agda.TypeChecking.Monad.Debug.MonadDebug (Control.Monad.Trans.Identity.IdentityT m)
instance Agda.TypeChecking.Monad.Debug.MonadDebug m => Agda.TypeChecking.Monad.Debug.MonadDebug (Agda.Utils.ListT.ListT m)


-- | Collect statistics.
module Agda.TypeChecking.Monad.Statistics
class ReadTCState m => MonadStatistics m
modifyCounter :: MonadStatistics m => String -> (Integer -> Integer) -> m ()
modifyCounter :: (MonadStatistics m, MonadStatistics n, MonadTrans t, t n ~ m) => String -> (Integer -> Integer) -> m ()

-- | Increase specified counter by <tt>1</tt>.
tick :: MonadStatistics m => String -> m ()

-- | Increase specified counter by <tt>n</tt>.
tickN :: MonadStatistics m => String -> Integer -> m ()

-- | Set the specified counter to the maximum of its current value and
--   <tt>n</tt>.
tickMax :: MonadStatistics m => String -> Integer -> m ()

-- | Get the statistics.
getStatistics :: ReadTCState m => m Statistics

-- | Modify the statistics via given function.
modifyStatistics :: (Statistics -> Statistics) -> TCM ()

-- | Print the given statistics.
printStatistics :: (MonadDebug m, MonadTCEnv m, HasOptions m) => Maybe TopLevelModuleName -> Statistics -> m ()
instance Agda.TypeChecking.Monad.Statistics.MonadStatistics m => Agda.TypeChecking.Monad.Statistics.MonadStatistics (Control.Monad.Trans.Except.ExceptT e m)
instance Agda.TypeChecking.Monad.Statistics.MonadStatistics m => Agda.TypeChecking.Monad.Statistics.MonadStatistics (Control.Monad.Trans.Maybe.MaybeT m)
instance Agda.TypeChecking.Monad.Statistics.MonadStatistics m => Agda.TypeChecking.Monad.Statistics.MonadStatistics (Control.Monad.Trans.Reader.ReaderT r m)
instance Agda.TypeChecking.Monad.Statistics.MonadStatistics m => Agda.TypeChecking.Monad.Statistics.MonadStatistics (Control.Monad.Trans.State.Lazy.StateT s m)
instance (Agda.TypeChecking.Monad.Statistics.MonadStatistics m, GHC.Base.Monoid w) => Agda.TypeChecking.Monad.Statistics.MonadStatistics (Control.Monad.Trans.Writer.Lazy.WriterT w m)
instance Agda.TypeChecking.Monad.Statistics.MonadStatistics Agda.TypeChecking.Monad.Base.TCM

module Agda.TypeChecking.Monad.Caching

-- | Writes a <a>TypeCheckAction</a> to the current log, using the current
--   <a>PostScopeState</a>
writeToCurrentLog :: (MonadDebug m, MonadTCState m, ReadTCState m) => TypeCheckAction -> m ()

-- | Reads the next entry in the cached type check log, if present.
readFromCachedLog :: (MonadDebug m, MonadTCState m, ReadTCState m) => m (Maybe (TypeCheckAction, PostScopeState))

-- | Empties the "to read" CachedState. To be used when it gets invalid.
cleanCachedLog :: (MonadDebug m, MonadTCState m) => m ()

-- | Caches the current type check log. Discardes the old cache. Does
--   nothing if caching is inactive.
cacheCurrentLog :: (MonadDebug m, MonadTCState m) => m ()

-- | Makes sure that the <a>stLoadedFileCache</a> is <a>Just</a>, with a
--   clean current log. Crashes is <a>stLoadedFileCache</a> is already
--   active with a dirty log. Should be called when we start typechecking
--   the current file.
activateLoadedFileCache :: (HasOptions m, MonadDebug m, MonadTCState m) => m ()

-- | To be called before any write or restore calls.
cachingStarts :: (MonadDebug m, MonadTCState m, ReadTCState m) => m ()
areWeCaching :: ReadTCState m => m Bool

-- | Runs the action and restores the current cache at the end of it.
localCache :: (MonadTCState m, ReadTCState m) => m a -> m a

-- | Runs the action without cache and restores the current cache at the
--   end of it.
withoutCache :: (MonadTCState m, ReadTCState m) => m a -> m a
restorePostScopeState :: (MonadDebug m, MonadTCState m) => PostScopeState -> m ()


-- | Measure CPU time for individual phases of the Agda pipeline.
module Agda.TypeChecking.Monad.Benchmark

-- | Monad with access to benchmarking data.
class (Ord (BenchPhase m), Functor m, MonadIO m) => MonadBench m
type BenchPhase m
getBenchmark :: MonadBench m => m (Benchmark (BenchPhase m))

-- | When profile options are set or changed, we need to turn benchmarking
--   on or off.
updateBenchmarkingStatus :: TCM ()

-- | Bill a computation to a specific account. Works even if the
--   computation is aborted by an exception.
billTo :: MonadBench m => Account (BenchPhase m) -> m c -> m c

-- | Bill a pure computation to a specific account.
billPureTo :: MonadBench m => Account (BenchPhase m) -> c -> m c

-- | Bill a CPS function to an account. Can't handle exceptions.
billToCPS :: MonadBench m => Account (BenchPhase m) -> ((b -> m c) -> m c) -> (b -> m c) -> m c

-- | Resets the account and the timing information.
reset :: MonadBench m => m ()

-- | Prints the accumulated benchmark results. Does nothing if no benchmark
--   profiling is enabled.
print :: MonadTCM tcm => tcm ()

module Agda.TypeChecking.DropArgs

-- | When making a function projection-like, we drop the first <tt>n</tt>
--   arguments.
class DropArgs a
dropArgs :: DropArgs a => Int -> a -> a
instance Agda.TypeChecking.DropArgs.DropArgs a => Agda.TypeChecking.DropArgs.DropArgs (GHC.Maybe.Maybe a)
instance Agda.TypeChecking.DropArgs.DropArgs Agda.Syntax.Internal.Telescope
instance Agda.TypeChecking.DropArgs.DropArgs Agda.Utils.Permutation.Permutation
instance Agda.TypeChecking.DropArgs.DropArgs Agda.Syntax.Internal.Clause
instance Agda.TypeChecking.DropArgs.DropArgs Agda.TypeChecking.Monad.Base.FunctionInverse
instance Agda.TypeChecking.DropArgs.DropArgs Agda.Syntax.Internal.Term
instance Agda.TypeChecking.DropArgs.DropArgs Agda.TypeChecking.CompiledClause.CompiledClauses
instance Agda.TypeChecking.DropArgs.DropArgs Agda.TypeChecking.Coverage.SplitTree.SplitTree


-- | Extract all names and meta-variables from things.
module Agda.Syntax.Internal.Names

-- | Some or all of the <a>QName</a>s that can be found in the given thing.
namesIn :: (NamesIn a, Collection QName m) => a -> m

-- | Some or all of the <a>QName</a>s that can be found in the given thing.
namesIn' :: (NamesIn a, Monoid m) => (QName -> m) -> a -> m

-- | Some or all of the meta-variables that can be found in the given
--   thing.
metasIn :: (NamesIn a, Collection MetaId m) => a -> m

-- | Some or all of the meta-variables that can be found in the given
--   thing.
metasIn' :: (NamesIn a, Monoid m) => (MetaId -> m) -> a -> m

-- | Some or all of the names and meta-variables that can be found in the
--   given thing.
namesAndMetasIn :: (NamesIn a, Collection QName m1, Collection MetaId m2) => a -> (m1, m2)
class NamesIn a

-- | Some or all of the names and meta-variables that can be found in the
--   given thing.
namesAndMetasIn' :: (NamesIn a, Monoid m) => (Either QName MetaId -> m) -> a -> m

-- | Some or all of the names and meta-variables that can be found in the
--   given thing.
namesAndMetasIn' :: (NamesIn a, Monoid m, Foldable f, NamesIn b, f b ~ a) => (Either QName MetaId -> m) -> a -> m
newtype PSyn
PSyn :: PatternSynDefn -> PSyn
instance Agda.Syntax.Internal.Names.NamesIn Agda.Syntax.Internal.Names.PSyn
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (GHC.Maybe.Maybe a)
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (Data.Strict.Maybe.Maybe a)
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn [a]
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (Agda.Utils.List1.List1 a)
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (Data.Set.Internal.Set a)
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (Data.Map.Internal.Map k a)
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (Agda.Syntax.Common.Named n a)
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (Agda.Syntax.Internal.Abs a)
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (Agda.TypeChecking.CompiledClause.WithArity a)
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (Agda.TypeChecking.Monad.Base.Open a)
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (Agda.Syntax.Concrete.FieldAssignment' a)
instance (Agda.Syntax.Internal.Names.NamesIn a, Agda.Syntax.Internal.Names.NamesIn b) => Agda.Syntax.Internal.Names.NamesIn (Agda.Syntax.Internal.Dom' a b)
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (Agda.Syntax.Internal.Tele a)
instance (Agda.Syntax.Internal.Names.NamesIn a, Agda.Syntax.Internal.Names.NamesIn b) => Agda.Syntax.Internal.Names.NamesIn (a, b)
instance (Agda.Syntax.Internal.Names.NamesIn a, Agda.Syntax.Internal.Names.NamesIn b, Agda.Syntax.Internal.Names.NamesIn c) => Agda.Syntax.Internal.Names.NamesIn (a, b, c)
instance (Agda.Syntax.Internal.Names.NamesIn a, Agda.Syntax.Internal.Names.NamesIn b, Agda.Syntax.Internal.Names.NamesIn c, Agda.Syntax.Internal.Names.NamesIn d) => Agda.Syntax.Internal.Names.NamesIn (a, b, c, d)
instance (Agda.Syntax.Internal.Names.NamesIn a, Agda.Syntax.Internal.Names.NamesIn b, Agda.Syntax.Internal.Names.NamesIn c, Agda.Syntax.Internal.Names.NamesIn d, Agda.Syntax.Internal.Names.NamesIn e) => Agda.Syntax.Internal.Names.NamesIn (a, b, c, d, e)
instance (Agda.Syntax.Internal.Names.NamesIn a, Agda.Syntax.Internal.Names.NamesIn b, Agda.Syntax.Internal.Names.NamesIn c, Agda.Syntax.Internal.Names.NamesIn d, Agda.Syntax.Internal.Names.NamesIn e, Agda.Syntax.Internal.Names.NamesIn f) => Agda.Syntax.Internal.Names.NamesIn (a, b, c, d, e, f)
instance Agda.Syntax.Internal.Names.NamesIn Agda.TypeChecking.Monad.Base.CompKit
instance Agda.Syntax.Internal.Names.NamesIn Agda.Syntax.Abstract.Name.QName
instance Agda.Syntax.Internal.Names.NamesIn Agda.Syntax.Common.MetaId
instance Agda.Syntax.Internal.Names.NamesIn Agda.Syntax.Internal.ConHead
instance Agda.Syntax.Internal.Names.NamesIn GHC.Types.Bool
instance Agda.Syntax.Internal.Names.NamesIn Agda.TypeChecking.Monad.Base.Definition
instance Agda.Syntax.Internal.Names.NamesIn Agda.TypeChecking.Monad.Base.Defn
instance Agda.Syntax.Internal.Names.NamesIn Agda.Syntax.Internal.Clause
instance Agda.Syntax.Internal.Names.NamesIn Agda.TypeChecking.CompiledClause.CompiledClauses
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (Agda.TypeChecking.CompiledClause.Case a)
instance Agda.Syntax.Internal.Names.NamesIn (Agda.Syntax.Internal.Pattern' a)
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (Agda.Syntax.Internal.Type' a)
instance Agda.Syntax.Internal.Names.NamesIn Agda.Syntax.Internal.Sort
instance Agda.Syntax.Internal.Names.NamesIn Agda.Syntax.Internal.Term
instance Agda.Syntax.Internal.Names.NamesIn Agda.Syntax.Internal.Level
instance Agda.Syntax.Internal.Names.NamesIn Agda.Syntax.Internal.PlusLevel
instance Agda.Syntax.Internal.Names.NamesIn Agda.Syntax.Literal.Literal
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (Agda.Syntax.Internal.Substitution' a)
instance Agda.Syntax.Internal.Names.NamesIn Agda.TypeChecking.Monad.Base.DisplayForm
instance Agda.Syntax.Internal.Names.NamesIn Agda.TypeChecking.Monad.Base.DisplayTerm
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (Agda.TypeChecking.Monad.Base.Builtin a)
instance Agda.Syntax.Internal.Names.NamesIn Agda.TypeChecking.Monad.Base.PrimFun
instance Agda.Syntax.Internal.Names.NamesIn Agda.TypeChecking.Monad.Base.Section
instance Agda.Syntax.Internal.Names.NamesIn Agda.TypeChecking.Monad.Base.NLPat
instance Agda.Syntax.Internal.Names.NamesIn Agda.TypeChecking.Monad.Base.NLPType
instance Agda.Syntax.Internal.Names.NamesIn Agda.TypeChecking.Monad.Base.NLPSort
instance Agda.Syntax.Internal.Names.NamesIn Agda.TypeChecking.Monad.Base.RewriteRule
instance (Agda.Syntax.Internal.Names.NamesIn a, Agda.Syntax.Internal.Names.NamesIn b) => Agda.Syntax.Internal.Names.NamesIn (Data.HashMap.Internal.HashMap a b)
instance Agda.Syntax.Internal.Names.NamesIn Agda.TypeChecking.Monad.Base.System
instance Agda.Syntax.Internal.Names.NamesIn Agda.TypeChecking.Monad.Base.ExtLamInfo
instance Agda.Syntax.Internal.Names.NamesIn a => Agda.Syntax.Internal.Names.NamesIn (Agda.TypeChecking.Monad.Base.FunctionInverse' a)
instance Agda.Syntax.Internal.Names.NamesIn Agda.Syntax.Treeless.TTerm
instance Agda.Syntax.Internal.Names.NamesIn Agda.Syntax.Treeless.TAlt
instance Agda.Syntax.Internal.Names.NamesIn Agda.Syntax.Treeless.CaseType
instance Agda.Syntax.Internal.Names.NamesIn Agda.Syntax.Treeless.CaseInfo
instance Agda.Syntax.Internal.Names.NamesIn Agda.Syntax.Treeless.Compiled
instance Agda.Syntax.Internal.Names.NamesIn Agda.Syntax.Internal.ConPatternInfo
instance Agda.Syntax.Internal.Names.NamesIn (Agda.Syntax.Abstract.Pattern' a)
instance Agda.Syntax.Internal.Names.NamesIn Agda.Syntax.Abstract.Name.AmbiguousQName

module Agda.Interaction.Output
type OutputForm a b = OutputForm_boot TCErr a b
type OutputConstraint a b = OutputConstraint_boot TCErr a b

module Agda.TypeChecking.Warnings
class (MonadPretty m, MonadError TCErr m) => MonadWarning m

-- | Store a warning and generate highlighting from it.
addWarning :: MonadWarning m => TCWarning -> m ()

-- | Store a warning and generate highlighting from it.
addWarning :: (MonadWarning m, MonadWarning n, MonadTrans t, t n ~ m) => TCWarning -> m ()
warning'_ :: MonadWarning m => CallStack -> Warning -> m TCWarning
warning_ :: (HasCallStack, MonadWarning m) => Warning -> m TCWarning
warning' :: MonadWarning m => CallStack -> Warning -> m ()
warning :: (HasCallStack, MonadWarning m) => Warning -> m ()
warnings :: (HasCallStack, MonadWarning m) => [Warning] -> m ()

-- | Raise every <tt>WARNING_ON_USAGE</tt> connected to a name.
raiseWarningsOnUsage :: (MonadWarning m, ReadTCState m) => QName -> m ()
isUnsolvedWarning :: Warning -> Bool
isMetaWarning :: Warning -> Bool
isMetaTCWarning :: TCWarning -> Bool
onlyShowIfUnsolved :: Warning -> Bool

-- | Classifying warnings: some are benign, others are (non-fatal) errors
data WhichWarnings

-- | warnings that will be turned into errors
ErrorWarnings :: WhichWarnings

-- | all warnings, including errors and benign ones Note: order of
--   constructors is important for the derived Ord instance
AllWarnings :: WhichWarnings
classifyWarning :: Warning -> WhichWarnings

-- | Assorted warnings and errors to be displayed to the user
data WarningsAndNonFatalErrors
tcWarnings :: WarningsAndNonFatalErrors -> [TCWarning]
nonFatalErrors :: WarningsAndNonFatalErrors -> [TCWarning]

-- | The only way to construct a empty WarningsAndNonFatalErrors
emptyWarningsAndNonFatalErrors :: WarningsAndNonFatalErrors
classifyWarnings :: [TCWarning] -> WarningsAndNonFatalErrors

-- | running the Parse monad
runPM :: PM a -> TCM a
instance GHC.Classes.Ord Agda.TypeChecking.Warnings.WhichWarnings
instance GHC.Classes.Eq Agda.TypeChecking.Warnings.WhichWarnings
instance Agda.TypeChecking.Warnings.MonadWarning m => Agda.TypeChecking.Warnings.MonadWarning (Control.Monad.Trans.Reader.ReaderT r m)
instance Agda.TypeChecking.Warnings.MonadWarning m => Agda.TypeChecking.Warnings.MonadWarning (Control.Monad.Trans.State.Lazy.StateT s m)
instance Agda.TypeChecking.Warnings.MonadWarning Agda.TypeChecking.Monad.Base.TCM

module Agda.Interaction.Response
type Response = Response_boot TCErr TCWarning WarningsAndNonFatalErrors
type Goals = Goals_boot TCErr
type Info_Error = Info_Error_boot TCErr TCWarning
type DisplayInfo = DisplayInfo_boot TCErr TCWarning WarningsAndNonFatalErrors
type GoalDisplayInfo = GoalDisplayInfo_boot TCErr

-- | Assorted warnings and errors to be displayed to the user
data WarningsAndNonFatalErrors

-- | Callback fuction to call when there is a response to give to the
--   interactive frontend.
--   
--   Note that the response is given in pieces and incrementally, so the
--   user can have timely response even during long computations.
--   
--   Typical <a>InteractionOutputCallback</a> functions:
--   
--   <ul>
--   <li>Convert the response into a <a>String</a> representation and print
--   it on standard output (suitable for inter-process communication).</li>
--   <li>Put the response into a mutable variable stored in the closure of
--   the <a>InteractionOutputCallback</a> function. (suitable for
--   intra-process communication).</li>
--   </ul>
type InteractionOutputCallback = Response_boot TCErr TCWarning WarningsAndNonFatalErrors -> TCM ()

-- | The default <a>InteractionOutputCallback</a> function prints certain
--   things to stdout (other things generate internal errors).
defaultInteractionOutputCallback :: InteractionOutputCallback


-- | Lenses for <a>TCState</a> and more.
module Agda.TypeChecking.Monad.State

-- | Resets the non-persistent part of the type checking state.
resetState :: TCM ()

-- | Resets all of the type checking state.
--   
--   Keep only <a>Benchmark</a> and backend information.
resetAllState :: TCM ()

-- | Restore <a>TCState</a> after performing subcomputation.
--   
--   In contrast to <a>localState</a>, the <a>Benchmark</a> info from the
--   subcomputation is saved.
localTCState :: TCM a -> TCM a

-- | Same as <a>localTCState</a> but also returns the state in which we
--   were just before reverting it.
localTCStateSaving :: TCM a -> TCM (a, TCState)

-- | Same as <a>localTCState</a> but keep all warnings.
localTCStateSavingWarnings :: TCM a -> TCM a
data SpeculateResult
SpeculateAbort :: SpeculateResult
SpeculateCommit :: SpeculateResult

-- | Allow rolling back the state changes of a TCM computation.
speculateTCState :: TCM (a, SpeculateResult) -> TCM a
speculateTCState_ :: TCM SpeculateResult -> TCM ()

-- | A fresh TCM instance.
--   
--   The computation is run in a fresh state, with the exception that the
--   persistent state is preserved. If the computation changes the state,
--   then these changes are ignored, except for changes to the persistent
--   state. (Changes to the persistent state are also ignored if errors
--   other than type errors or IO exceptions are encountered.)
freshTCM :: TCM a -> TCM (Either TCErr a)
lensPersistentState :: Lens' TCState PersistentTCState
updatePersistentState :: (PersistentTCState -> PersistentTCState) -> TCState -> TCState
modifyPersistentState :: (PersistentTCState -> PersistentTCState) -> TCM ()

-- | Lens for <a>stAccumStatistics</a>.
lensAccumStatisticsP :: Lens' PersistentTCState Statistics
lensAccumStatistics :: Lens' TCState Statistics

-- | Get the current scope.
getScope :: ReadTCState m => m ScopeInfo

-- | Set the current scope.
setScope :: ScopeInfo -> TCM ()

-- | Modify the current scope without updating the inverse maps.
modifyScope_ :: MonadTCState m => (ScopeInfo -> ScopeInfo) -> m ()

-- | Modify the current scope.
modifyScope :: MonadTCState m => (ScopeInfo -> ScopeInfo) -> m ()

-- | Get a part of the current scope.
useScope :: ReadTCState m => Lens' ScopeInfo a -> m a

-- | Run a computation in a modified scope.
locallyScope :: ReadTCState m => Lens' ScopeInfo a -> (a -> a) -> m b -> m b

-- | Run a computation in a local scope.
withScope :: ReadTCState m => ScopeInfo -> m a -> m (a, ScopeInfo)

-- | Same as <a>withScope</a>, but discard the scope from the computation.
withScope_ :: ReadTCState m => ScopeInfo -> m a -> m a

-- | Discard any changes to the scope by a computation.
localScope :: TCM a -> TCM a

-- | Scope error.
notInScopeError :: QName -> TCM a
notInScopeWarning :: QName -> TCM ()

-- | Debug print the scope.
printScope :: String -> Int -> String -> TCM ()
modifySignature :: MonadTCState m => (Signature -> Signature) -> m ()
modifyImportedSignature :: MonadTCState m => (Signature -> Signature) -> m ()
getSignature :: ReadTCState m => m Signature

-- | Update a possibly imported definition. Warning: changes made to
--   imported definitions (during type checking) will not persist outside
--   the current module. This function is currently used to update the
--   compiled representation of a function during compilation.
modifyGlobalDefinition :: MonadTCState m => QName -> (Definition -> Definition) -> m ()
setSignature :: MonadTCState m => Signature -> m ()

-- | Run some computation in a different signature, restore original
--   signature.
withSignature :: (ReadTCState m, MonadTCState m) => Signature -> m a -> m a
addRewriteRulesFor :: QName -> RewriteRules -> [QName] -> Signature -> Signature
setMatchableSymbols :: QName -> [QName] -> Signature -> Signature
modifyRecEta :: MonadTCState m => QName -> (EtaEquality -> EtaEquality) -> m ()
lookupDefinition :: QName -> Signature -> Maybe Definition
updateDefinitions :: (Definitions -> Definitions) -> Signature -> Signature
updateDefinition :: QName -> (Definition -> Definition) -> Signature -> Signature
updateTheDef :: (Defn -> Defn) -> Definition -> Definition
updateDefType :: (Type -> Type) -> Definition -> Definition
updateDefArgOccurrences :: ([Occurrence] -> [Occurrence]) -> Definition -> Definition
updateDefPolarity :: ([Polarity] -> [Polarity]) -> Definition -> Definition
updateDefCompiledRep :: (CompiledRepresentation -> CompiledRepresentation) -> Definition -> Definition
addCompilerPragma :: BackendName -> CompilerPragma -> Definition -> Definition
updateFunClauses :: ([Clause] -> [Clause]) -> Defn -> Defn
updateCovering :: ([Clause] -> [Clause]) -> Defn -> Defn
updateCompiledClauses :: (Maybe CompiledClauses -> Maybe CompiledClauses) -> Defn -> Defn
updateDefCopatternLHS :: (Bool -> Bool) -> Definition -> Definition
updateDefBlocked :: (Blocked_ -> Blocked_) -> Definition -> Definition

-- | Tries to convert a raw top-level module name to a top-level module
--   name.
topLevelModuleName :: RawTopLevelModuleName -> TCM TopLevelModuleName

-- | Set the top-level module. This affects the global module id of freshly
--   generated names.
setTopLevelModule :: TopLevelModuleName -> TCM ()

-- | The name of the current top-level module, if any.
currentTopLevelModule :: (MonadTCEnv m, ReadTCState m) => m (Maybe TopLevelModuleName)

-- | Use a different top-level module for a computation. Used when
--   generating names for imported modules.
withTopLevelModule :: TopLevelModuleName -> TCM a -> TCM a
currentModuleNameHash :: ReadTCState m => m ModuleNameHash
addForeignCode :: BackendName -> String -> TCM ()
getInteractionOutputCallback :: ReadTCState m => m InteractionOutputCallback
appInteractionOutputCallback :: Response -> TCM ()
setInteractionOutputCallback :: InteractionOutputCallback -> TCM ()
getPatternSyns :: ReadTCState m => m PatternSynDefns
setPatternSyns :: PatternSynDefns -> TCM ()

-- | Lens for <a>stPatternSyns</a>.
modifyPatternSyns :: (PatternSynDefns -> PatternSynDefns) -> TCM ()
getPatternSynImports :: ReadTCState m => m PatternSynDefns

-- | Get both local and imported pattern synonyms
getAllPatternSyns :: ReadTCState m => m PatternSynDefns
lookupPatternSyn :: AmbiguousQName -> TCM PatternSynDefn
lookupSinglePatternSyn :: QName -> TCM PatternSynDefn

-- | Lens getter for <a>Benchmark</a> from <a>TCState</a>.
theBenchmark :: TCState -> Benchmark

-- | Lens map for <a>Benchmark</a>.
updateBenchmark :: (Benchmark -> Benchmark) -> TCState -> TCState

-- | Lens getter for <a>Benchmark</a> from <a>TCMT</a>.
getBenchmark :: TCM Benchmark

-- | Lens modify for <a>Benchmark</a>.
modifyBenchmark :: (Benchmark -> Benchmark) -> TCM ()

-- | Lens for <a>stInstanceDefs</a>.
updateInstanceDefs :: (TempInstanceTable -> TempInstanceTable) -> TCState -> TCState
modifyInstanceDefs :: (TempInstanceTable -> TempInstanceTable) -> TCM ()
getAllInstanceDefs :: TCM TempInstanceTable
getAnonInstanceDefs :: TCM (Set QName)

-- | Remove an instance from the set of unresolved instances.
clearUnknownInstance :: QName -> TCM ()

-- | Add an instance whose type is still unresolved.
addUnknownInstance :: QName -> TCM ()

module Agda.TypeChecking.Monad.Trace
interestingCall :: Call -> Bool
class (MonadTCEnv m, ReadTCState m) => MonadTrace m

-- | Record a function call in the trace.
traceCall :: MonadTrace m => Call -> m a -> m a
traceCallM :: MonadTrace m => m Call -> m a -> m a

-- | Like <a>traceCall</a>, but resets <a>envCall</a> and the current
--   ranges to the previous values in the continuation.
traceCallCPS :: MonadTrace m => Call -> ((a -> m b) -> m b) -> (a -> m b) -> m b
traceClosureCall :: MonadTrace m => Closure Call -> m a -> m a

-- | Lispify and print the given highlighting information.
printHighlightingInfo :: MonadTrace m => RemoveTokenBasedHighlighting -> HighlightingInfo -> m ()

-- | Lispify and print the given highlighting information.
printHighlightingInfo :: (MonadTrace m, MonadTrans t, MonadTrace n, t n ~ m) => RemoveTokenBasedHighlighting -> HighlightingInfo -> m ()
getCurrentRange :: MonadTCEnv m => m Range

-- | Sets the current range (for error messages etc.) to the range of the
--   given object, if it has a range (i.e., its range is not
--   <a>noRange</a>).
setCurrentRange :: (MonadTrace m, HasRange x) => x -> m a -> m a

-- | <tt>highlightAsTypeChecked rPre r m</tt> runs <tt>m</tt> and returns
--   its result. Additionally, some code may be highlighted:
--   
--   <ul>
--   <li>If <tt>r</tt> is non-empty and not a sub-range of <tt>rPre</tt>
--   (after <a>continuousPerLine</a> has been applied to both): <tt>r</tt>
--   is highlighted as being type-checked while <tt>m</tt> is running (this
--   highlighting is removed if <tt>m</tt> completes
--   <i>successfully</i>).</li>
--   <li>Otherwise: Highlighting is removed for <tt>rPre - r</tt> before
--   <tt>m</tt> runs, and if <tt>m</tt> completes successfully, then
--   <tt>rPre - r</tt> is highlighted as being type-checked.</li>
--   </ul>
highlightAsTypeChecked :: MonadTrace m => Range -> Range -> m a -> m a
instance Agda.TypeChecking.Monad.Trace.MonadTrace m => Agda.TypeChecking.Monad.Trace.MonadTrace (Control.Monad.Trans.Identity.IdentityT m)
instance Agda.TypeChecking.Monad.Trace.MonadTrace m => Agda.TypeChecking.Monad.Trace.MonadTrace (Control.Monad.Trans.Reader.ReaderT r m)
instance Agda.TypeChecking.Monad.Trace.MonadTrace m => Agda.TypeChecking.Monad.Trace.MonadTrace (Control.Monad.Trans.State.Lazy.StateT s m)
instance (Agda.TypeChecking.Monad.Trace.MonadTrace m, GHC.Base.Monoid w) => Agda.TypeChecking.Monad.Trace.MonadTrace (Control.Monad.Trans.Writer.Lazy.WriterT w m)
instance Agda.TypeChecking.Monad.Trace.MonadTrace m => Agda.TypeChecking.Monad.Trace.MonadTrace (Control.Monad.Trans.Except.ExceptT e m)
instance Agda.TypeChecking.Monad.Trace.MonadTrace Agda.TypeChecking.Monad.Base.TCM


-- | Stuff for sized types that does not require modules
--   <a>Agda.TypeChecking.Reduce</a> or
--   <a>Agda.TypeChecking.Constraints</a> (which import
--   <a>Agda.TypeChecking.Monad</a>).
module Agda.TypeChecking.Monad.SizedTypes

-- | Result of querying whether size variable <tt>i</tt> is bounded by
--   another size.
data BoundedSize

-- | yes <tt>i : Size&lt; t</tt>
BoundedLt :: Term -> BoundedSize
BoundedNo :: BoundedSize

-- | Check if a type is the <a>primSize</a> type. The argument should be
--   <tt>reduce</tt>d.
class IsSizeType a
isSizeType :: (IsSizeType a, HasOptions m, HasBuiltins m) => a -> m (Maybe BoundedSize)
isSizeTypeTest :: (HasOptions m, HasBuiltins m) => m (Term -> Maybe BoundedSize)
getBuiltinDefName :: HasBuiltins m => BuiltinId -> m (Maybe QName)
getBuiltinSize :: HasBuiltins m => m (Maybe QName, Maybe QName)
isSizeNameTest :: (HasOptions m, HasBuiltins m) => m (QName -> Bool)
isSizeNameTestRaw :: (HasOptions m, HasBuiltins m) => m (QName -> Bool)

-- | Test whether OPTIONS --sized-types and whether the size built-ins are
--   defined.
haveSizedTypes :: TCM Bool

-- | Test whether the SIZELT builtin is defined.
haveSizeLt :: TCM Bool

-- | Add polarity info to a SIZE builtin.
builtinSizeHook :: BuiltinId -> QName -> Type -> TCM ()

-- | The sort of built-in types <tt>SIZE</tt> and <tt>SIZELT</tt>.
sizeSort :: Sort

-- | The type of built-in types <tt>SIZE</tt> and <tt>SIZELT</tt>.
sizeUniv :: Type

-- | The built-in type <tt>SIZE</tt> with user-given name.
sizeType_ :: QName -> Type

-- | The built-in type <tt>SIZE</tt>.
sizeType :: (HasBuiltins m, MonadTCEnv m, ReadTCState m) => m Type

-- | The name of <tt>SIZESUC</tt>.
sizeSucName :: (HasBuiltins m, HasOptions m) => m (Maybe QName)
sizeSuc :: HasBuiltins m => Nat -> Term -> m Term
sizeSuc_ :: QName -> Term -> Term

-- | Transform list of terms into a term build from binary maximum.
sizeMax :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => List1 Term -> m Term

-- | A useful view on sizes.
data SizeView
SizeInf :: SizeView
SizeSuc :: Term -> SizeView
OtherSize :: Term -> SizeView

-- | Expects argument to be <tt>reduce</tt>d.
sizeView :: (HasBuiltins m, MonadTCEnv m, ReadTCState m) => Term -> m SizeView

-- | A de Bruijn index under some projections.
data ProjectedVar
ProjectedVar :: Int -> [(ProjOrigin, QName)] -> ProjectedVar
[pvIndex] :: ProjectedVar -> Int
[prProjs] :: ProjectedVar -> [(ProjOrigin, QName)]
viewProjectedVar :: Term -> Maybe ProjectedVar
unviewProjectedVar :: ProjectedVar -> Term
type Offset = Nat

-- | A deep view on sizes.
data DeepSizeView
DSizeInf :: DeepSizeView
DSizeVar :: ProjectedVar -> Offset -> DeepSizeView
DSizeMeta :: MetaId -> Elims -> Offset -> DeepSizeView
DOtherSize :: Term -> DeepSizeView
data SizeViewComparable a
NotComparable :: SizeViewComparable a
YesAbove :: DeepSizeView -> a -> SizeViewComparable a
YesBelow :: DeepSizeView -> a -> SizeViewComparable a

-- | <tt>sizeViewComparable v w</tt> checks whether <tt>v &gt;= w</tt>
--   (then <tt>Left</tt>) or <tt>v &lt;= w</tt> (then <tt>Right</tt>). If
--   uncomparable, it returns <tt>NotComparable</tt>.
sizeViewComparable :: DeepSizeView -> DeepSizeView -> SizeViewComparable ()
sizeViewSuc_ :: QName -> DeepSizeView -> DeepSizeView

-- | <tt>sizeViewPred k v</tt> decrements <tt>v</tt> by <tt>k</tt> (must be
--   possible!).
sizeViewPred :: Nat -> DeepSizeView -> DeepSizeView

-- | <tt>sizeViewOffset v</tt> returns the number of successors or Nothing
--   when infty.
sizeViewOffset :: DeepSizeView -> Maybe Offset

-- | Remove successors common to both sides.
removeSucs :: (DeepSizeView, DeepSizeView) -> (DeepSizeView, DeepSizeView)

-- | Turn a size view into a term.
unSizeView :: SizeView -> TCM Term
unDeepSizeView :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => DeepSizeView -> m Term
type SizeMaxView = List1 DeepSizeView
type SizeMaxView' = [DeepSizeView]
maxViewMax :: SizeMaxView -> SizeMaxView -> SizeMaxView

-- | <tt>maxViewCons v ws = max v ws</tt>. It only adds <tt>v</tt> to
--   <tt>ws</tt> if it is not subsumed by an element of <tt>ws</tt>.
maxViewCons :: DeepSizeView -> SizeMaxView -> SizeMaxView

-- | <tt>sizeViewComparableWithMax v ws</tt> tries to find <tt>w</tt> in
--   <tt>ws</tt> that compares with <tt>v</tt> and singles this out.
--   Precondition: <tt>v /= DSizeInv</tt>.
sizeViewComparableWithMax :: DeepSizeView -> SizeMaxView -> SizeViewComparable SizeMaxView'
maxViewSuc_ :: QName -> SizeMaxView -> SizeMaxView
unMaxView :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => SizeMaxView -> m Term
instance GHC.Show.Show Agda.TypeChecking.Monad.SizedTypes.BoundedSize
instance GHC.Classes.Eq Agda.TypeChecking.Monad.SizedTypes.BoundedSize
instance GHC.Show.Show Agda.TypeChecking.Monad.SizedTypes.ProjectedVar
instance GHC.Show.Show Agda.TypeChecking.Monad.SizedTypes.DeepSizeView
instance GHC.Base.Functor Agda.TypeChecking.Monad.SizedTypes.SizeViewComparable
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Monad.SizedTypes.DeepSizeView
instance GHC.Classes.Eq Agda.TypeChecking.Monad.SizedTypes.ProjectedVar
instance Agda.TypeChecking.Monad.SizedTypes.IsSizeType a => Agda.TypeChecking.Monad.SizedTypes.IsSizeType (Agda.Syntax.Internal.Dom a)
instance Agda.TypeChecking.Monad.SizedTypes.IsSizeType a => Agda.TypeChecking.Monad.SizedTypes.IsSizeType (b, a)
instance Agda.TypeChecking.Monad.SizedTypes.IsSizeType a => Agda.TypeChecking.Monad.SizedTypes.IsSizeType (Agda.Syntax.Internal.Type' a)
instance Agda.TypeChecking.Monad.SizedTypes.IsSizeType Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Monad.SizedTypes.IsSizeType Agda.TypeChecking.Monad.Base.CompareAs

module Agda.TypeChecking.Monad.Open

-- | Create an open term in the current context.
makeOpen :: (ReadTCState m, MonadTCEnv m) => a -> m (Open a)

-- | Extract the value from an open term. The checkpoint at which it was
--   created must be in scope.
getOpen :: (TermSubst a, MonadTCEnv m) => Open a -> m a

-- | Extract the value from an open term. If the checkpoint is no longer in
--   scope use the provided function to pull the object to the most recent
--   common checkpoint. The function is given the substitution from the
--   common ancestor to the checkpoint of the thing.
tryGetOpen :: (TermSubst a, ReadTCState m, MonadTCEnv m) => (Substitution -> a -> Maybe a) -> Open a -> m (Maybe a)

-- | An <a>Open</a> is closed if it has checkpoint 0.
isClosed :: Open a -> Bool

module Agda.TypeChecking.Monad.Mutual
noMutualBlock :: TCM a -> TCM a

-- | Pass the current mutual block id or create a new mutual block if we
--   are not already inside on.
inMutualBlock :: (MutualId -> TCM a) -> TCM a

-- | Set the mutual block info for a block, possibly overwriting the
--   existing one.
setMutualBlockInfo :: MutualId -> MutualInfo -> TCM ()

-- | Set the mutual block info for a block if non-existing.
insertMutualBlockInfo :: MutualId -> MutualInfo -> TCM ()

-- | Set the mutual block for a definition.
setMutualBlock :: MutualId -> QName -> TCM ()

-- | Get the current mutual block, if any, otherwise a fresh mutual block
--   is returned.
currentOrFreshMutualBlock :: TCM MutualId
lookupMutualBlock :: ReadTCState tcm => MutualId -> tcm MutualBlock

-- | Reverse lookup of a mutual block id for a name.
mutualBlockOf :: QName -> TCM MutualId

module Agda.TypeChecking.Monad.Context

-- | Modify a <a>Context</a> in a computation. Warning: does not update the
--   checkpoints. Use <tt>updateContext</tt> instead.
unsafeModifyContext :: MonadTCEnv tcm => (Context -> Context) -> tcm a -> tcm a

-- | Modify the <a>Dom'</a> part of context entries.
modifyContextInfo :: MonadTCEnv tcm => (forall e. Dom e -> Dom e) -> tcm a -> tcm a

-- | Change to top (=empty) context. Resets the checkpoints.
inTopContext :: (MonadTCEnv tcm, ReadTCState tcm) => tcm a -> tcm a

-- | Change to top (=empty) context, but don't update the checkpoints.
--   Totally not safe!
unsafeInTopContext :: (MonadTCEnv m, ReadTCState m) => m a -> m a

-- | Delete the last <tt>n</tt> bindings from the context.
--   
--   Doesn't update checkpoints! Use <a>escapeContext</a> or `updateContext
--   rho (drop n)` instead, for an appropriate substitution <tt>rho</tt>.
unsafeEscapeContext :: MonadTCM tcm => Int -> tcm a -> tcm a

-- | Delete the last <tt>n</tt> bindings from the context. Any occurrences
--   of these variables are replaced with the given <tt>err</tt>.
escapeContext :: MonadAddContext m => Impossible -> Int -> m a -> m a

-- | Add a new checkpoint. Do not use directly!
checkpoint :: (MonadDebug tcm, MonadTCM tcm, MonadFresh CheckpointId tcm, ReadTCState tcm) => Substitution -> tcm a -> tcm a

-- | Get the substitution from the context at a given checkpoint to the
--   current context.
checkpointSubstitution :: MonadTCEnv tcm => CheckpointId -> tcm Substitution

-- | Get the substitution from the context at a given checkpoint to the
--   current context.
checkpointSubstitution' :: MonadTCEnv tcm => CheckpointId -> tcm (Maybe Substitution)

-- | Get substitution <tt>Γ ⊢ ρ : Γm</tt> where <tt>Γ</tt> is the current
--   context and <tt>Γm</tt> is the module parameter telescope of module
--   <tt>m</tt>.
--   
--   Returns <tt>Nothing</tt> in case the we don't have a checkpoint for
--   <tt>m</tt>.
getModuleParameterSub :: (MonadTCEnv m, ReadTCState m) => ModuleName -> m (Maybe Substitution)
class MonadTCEnv m => MonadAddContext m

-- | <tt>addCtx x arg cont</tt> add a variable to the context.
--   
--   Chooses an unused <a>Name</a>.
--   
--   Warning: Does not update module parameter substitution!
addCtx :: MonadAddContext m => Name -> Dom Type -> m a -> m a

-- | Add a let bound variable to the context
addLetBinding' :: MonadAddContext m => Origin -> Name -> Term -> Dom Type -> m a -> m a

-- | Update the context. Requires a substitution that transports things
--   living in the old context to the new.
updateContext :: MonadAddContext m => Substitution -> (Context -> Context) -> m a -> m a
withFreshName :: MonadAddContext m => Range -> ArgName -> (Name -> m a) -> m a

-- | <tt>addCtx x arg cont</tt> add a variable to the context.
--   
--   Chooses an unused <a>Name</a>.
--   
--   Warning: Does not update module parameter substitution!
addCtx :: (MonadAddContext m, MonadAddContext n, MonadTransControl t, t n ~ m) => Name -> Dom Type -> m a -> m a

-- | Add a let bound variable to the context
addLetBinding' :: (MonadAddContext m, MonadAddContext n, MonadTransControl t, t n ~ m) => Origin -> Name -> Term -> Dom Type -> m a -> m a

-- | Update the context. Requires a substitution that transports things
--   living in the old context to the new.
updateContext :: (MonadAddContext m, MonadAddContext n, MonadTransControl t, t n ~ m) => Substitution -> (Context -> Context) -> m a -> m a
withFreshName :: (MonadAddContext m, MonadAddContext n, MonadTransControl t, t n ~ m) => Range -> ArgName -> (Name -> m a) -> m a

-- | Default implementation of addCtx in terms of updateContext
defaultAddCtx :: MonadAddContext m => Name -> Dom Type -> m a -> m a
withFreshName_ :: MonadAddContext m => ArgName -> (Name -> m a) -> m a

-- | Run the given TCM action, and register the given variable as being
--   shadowed by all the names with the same root that are added to the
--   context during this TCM action.
withShadowingNameTCM :: Name -> TCM b -> TCM b
addRecordNameContext :: (MonadAddContext m, MonadFresh NameId m) => Dom Type -> m b -> m b

-- | Various specializations of <tt>addCtx</tt>.
class AddContext b
addContext :: (AddContext b, MonadAddContext m) => b -> m a -> m a
contextSize :: AddContext b => b -> Nat

-- | Wrapper to tell <a>addContext</a> not to mark names as
--   <a>TypeError</a>. Used when adding a user-provided, but already type
--   checked, telescope to the context.
newtype KeepNames a
KeepNames :: a -> KeepNames a

-- | Go under an abstraction. Do not extend context in case of
--   <a>NoAbs</a>.
underAbstraction :: (Subst a, MonadAddContext m) => Dom Type -> Abs a -> (a -> m b) -> m b
underAbstraction' :: (Subst a, MonadAddContext m, AddContext (name, Dom Type)) => (String -> name) -> Dom Type -> Abs a -> (a -> m b) -> m b

-- | Go under an abstraction, treating <a>NoAbs</a> as <a>Abs</a>.
underAbstractionAbs :: (Subst a, MonadAddContext m) => Dom Type -> Abs a -> (a -> m b) -> m b
underAbstractionAbs' :: (Subst a, MonadAddContext m, AddContext (name, Dom Type)) => (String -> name) -> Dom Type -> Abs a -> (a -> m b) -> m b

-- | Go under an abstract without worrying about the type to add to the
--   context.
underAbstraction_ :: (Subst a, MonadAddContext m) => Abs a -> (a -> m b) -> m b

-- | Map a monadic function on the thing under the abstraction, adding the
--   abstracted variable to the context.
mapAbstraction :: (Subst a, Subst b, MonadAddContext m) => Dom Type -> (a -> m b) -> Abs a -> m (Abs b)
mapAbstraction_ :: (Subst a, Subst b, MonadAddContext m) => (a -> m b) -> Abs a -> m (Abs b)
getLetBindings :: MonadTCEnv tcm => tcm [(Name, LetBinding)]

-- | Add a let bound variable
defaultAddLetBinding' :: (ReadTCState m, MonadTCEnv m) => Origin -> Name -> Term -> Dom Type -> m a -> m a

-- | Add a let bound variable
addLetBinding :: MonadAddContext m => ArgInfo -> Origin -> Name -> Term -> Type -> m a -> m a

-- | Remove a let bound variable.
removeLetBinding :: MonadTCEnv m => Name -> m a -> m a

-- | Remove a let bound variable and all let bindings introduced after it.
--   For instance before printing its body to avoid folding the binding
--   itself, or using bindings defined later. Relies on the invariant that
--   names introduced later are sorted after earlier names.
removeLetBindingsFrom :: MonadTCEnv m => Name -> m a -> m a

-- | Get the current context.
getContext :: MonadTCEnv m => m Context

-- | Get the size of the current context.
getContextSize :: (Applicative m, MonadTCEnv m) => m Nat

-- | Generate <tt>[var (n - 1), ..., var 0]</tt> for all declarations in
--   the context.
getContextArgs :: (Applicative m, MonadTCEnv m) => m Args

-- | Generate <tt>[var (n - 1), ..., var 0]</tt> for all declarations in
--   the context.
getContextTerms :: (Applicative m, MonadTCEnv m) => m [Term]

-- | Get the current context as a <a>Telescope</a>.
getContextTelescope :: (Applicative m, MonadTCEnv m) => m Telescope

-- | Get the names of all declarations in the context.
getContextNames :: (Applicative m, MonadTCEnv m) => m [Name]

-- | get type of bound variable (i.e. deBruijn index)
lookupBV_ :: Nat -> Context -> Maybe ContextEntry
lookupBV' :: MonadTCEnv m => Nat -> m (Maybe ContextEntry)
lookupBV :: (MonadFail m, MonadTCEnv m) => Nat -> m (Dom (Name, Type))
domOfBV :: (Applicative m, MonadFail m, MonadTCEnv m) => Nat -> m (Dom Type)
typeOfBV :: (Applicative m, MonadFail m, MonadTCEnv m) => Nat -> m Type
nameOfBV' :: (Applicative m, MonadFail m, MonadTCEnv m) => Nat -> m (Maybe Name)
nameOfBV :: (Applicative m, MonadFail m, MonadTCEnv m) => Nat -> m Name

-- | Get the term corresponding to a named variable. If it is a lambda
--   bound variable the deBruijn index is returned and if it is a let bound
--   variable its definition is returned.
getVarInfo :: (MonadFail m, MonadTCEnv m) => Name -> m (Term, Dom Type)
instance Agda.TypeChecking.Monad.Context.MonadAddContext m => Agda.TypeChecking.Monad.Context.MonadAddContext (Agda.TypeChecking.Monad.Base.BlockT m)
instance Agda.TypeChecking.Monad.Context.AddContext (Agda.TypeChecking.Monad.Context.KeepNames GHC.Base.String, Agda.Syntax.Internal.Dom Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.Monad.Context.AddContext (Agda.TypeChecking.Monad.Context.KeepNames Agda.Syntax.Internal.Telescope)
instance Agda.TypeChecking.Monad.Context.AddContext a => Agda.TypeChecking.Monad.Context.AddContext [a]
instance Agda.TypeChecking.Monad.Context.AddContext (Agda.Syntax.Abstract.Name.Name, Agda.Syntax.Internal.Dom Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.Monad.Context.AddContext (Agda.Syntax.Internal.Dom (Agda.Syntax.Abstract.Name.Name, Agda.Syntax.Internal.Type))
instance Agda.TypeChecking.Monad.Context.AddContext (Agda.Syntax.Internal.Dom (GHC.Base.String, Agda.Syntax.Internal.Type))
instance Agda.TypeChecking.Monad.Context.AddContext ([Agda.Syntax.Abstract.Name.Name], Agda.Syntax.Internal.Dom Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.Monad.Context.AddContext (Agda.Utils.List1.List1 Agda.Syntax.Abstract.Name.Name, Agda.Syntax.Internal.Dom Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.Monad.Context.AddContext ([Agda.Syntax.Common.WithHiding Agda.Syntax.Abstract.Name.Name], Agda.Syntax.Internal.Dom Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.Monad.Context.AddContext (Agda.Utils.List1.List1 (Agda.Syntax.Common.WithHiding Agda.Syntax.Abstract.Name.Name), Agda.Syntax.Internal.Dom Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.Monad.Context.AddContext ([Agda.Syntax.Common.Arg Agda.Syntax.Abstract.Name.Name], Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.Monad.Context.AddContext (Agda.Utils.List1.List1 (Agda.Syntax.Common.Arg Agda.Syntax.Abstract.Name.Name), Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.Monad.Context.AddContext ([Agda.Syntax.Common.NamedArg Agda.Syntax.Abstract.Name.Name], Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.Monad.Context.AddContext (Agda.Utils.List1.List1 (Agda.Syntax.Common.NamedArg Agda.Syntax.Abstract.Name.Name), Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.Monad.Context.AddContext (GHC.Base.String, Agda.Syntax.Internal.Dom Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.Monad.Context.AddContext (Data.Text.Internal.Text, Agda.Syntax.Internal.Dom Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.Monad.Context.AddContext (Agda.Syntax.Internal.Dom Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.Monad.Context.AddContext Agda.Syntax.Abstract.Name.Name
instance Agda.TypeChecking.Monad.Context.AddContext GHC.Base.String
instance Agda.TypeChecking.Monad.Context.AddContext Agda.Syntax.Internal.Telescope
instance Agda.TypeChecking.Monad.Context.MonadAddContext m => Agda.TypeChecking.Monad.Context.MonadAddContext (Agda.Utils.Update.ChangeT m)
instance Agda.TypeChecking.Monad.Context.MonadAddContext m => Agda.TypeChecking.Monad.Context.MonadAddContext (Control.Monad.Trans.Except.ExceptT e m)
instance Agda.TypeChecking.Monad.Context.MonadAddContext m => Agda.TypeChecking.Monad.Context.MonadAddContext (Control.Monad.Trans.Identity.IdentityT m)
instance Agda.TypeChecking.Monad.Context.MonadAddContext m => Agda.TypeChecking.Monad.Context.MonadAddContext (Control.Monad.Trans.Maybe.MaybeT m)
instance Agda.TypeChecking.Monad.Context.MonadAddContext m => Agda.TypeChecking.Monad.Context.MonadAddContext (Control.Monad.Trans.Reader.ReaderT r m)
instance Agda.TypeChecking.Monad.Context.MonadAddContext m => Agda.TypeChecking.Monad.Context.MonadAddContext (Control.Monad.Trans.State.Lazy.StateT r m)
instance (GHC.Base.Monoid w, Agda.TypeChecking.Monad.Context.MonadAddContext m) => Agda.TypeChecking.Monad.Context.MonadAddContext (Control.Monad.Trans.Writer.Lazy.WriterT w m)
instance Agda.TypeChecking.Monad.Context.MonadAddContext m => Agda.TypeChecking.Monad.Context.MonadAddContext (Agda.Utils.ListT.ListT m)
instance Agda.TypeChecking.Monad.Context.MonadAddContext Agda.TypeChecking.Monad.Base.TCM


-- | Modality.
--   
--   Agda has support for several modalities, namely:
--   
--   <ul>
--   <li><a>Cohesion</a></li>
--   <li><a>Quantity</a></li>
--   <li><a>Relevance</a></li>
--   </ul>
--   
--   In order to type check such modalities, we must store the current
--   modality in the typing context. This module provides functions to
--   update the context based on a given modality.
--   
--   See <a>Agda.TypeChecking.Irrelevance</a>.
module Agda.TypeChecking.Monad.Modality

-- | Prepare parts of a parameter telescope for abstraction in constructors
--   and projections.
hideAndRelParams :: (LensHiding a, LensRelevance a) => a -> a

-- | Modify the context whenever going from the l.h.s. (term side) of the
--   typing judgement to the r.h.s. (type side).
workOnTypes :: (MonadTCEnv m, HasOptions m, MonadDebug m) => m a -> m a

-- | Internal workhorse, expects value of --experimental-irrelevance flag
--   as argument.
workOnTypes' :: MonadTCEnv m => Bool -> m a -> m a

-- | (Conditionally) wake up irrelevant variables and make them relevant.
--   For instance, in an irrelevant function argument otherwise irrelevant
--   variables may be used, so they are awoken before type checking the
--   argument.
--   
--   Also allow the use of irrelevant definitions.
applyRelevanceToContext :: (MonadTCEnv tcm, LensRelevance r) => r -> tcm a -> tcm a

-- | (Conditionally) wake up irrelevant variables and make them relevant.
--   For instance, in an irrelevant function argument otherwise irrelevant
--   variables may be used, so they are awoken before type checking the
--   argument.
--   
--   Precondition: <tt>Relevance /= Relevant</tt>
applyRelevanceToContextOnly :: MonadTCEnv tcm => Relevance -> tcm a -> tcm a

-- | Apply relevance <tt>rel</tt> the the relevance annotation of the
--   (typing/equality) judgement. This is part of the work done when going
--   into a <tt>rel</tt>-context.
--   
--   Precondition: <tt>Relevance /= Relevant</tt>
applyRelevanceToJudgementOnly :: MonadTCEnv tcm => Relevance -> tcm a -> tcm a

-- | Like <a>applyRelevanceToContext</a>, but only act on context if
--   <tt>--irrelevant-projections</tt>. See issue #2170.
applyRelevanceToContextFunBody :: (MonadTCM tcm, LensRelevance r) => r -> tcm a -> tcm a

-- | Apply the quantity to the quantity annotation of the (typing/equality)
--   judgement.
--   
--   Precondition: The quantity must not be <tt><a>Quantity1</a>
--   something</tt>.
applyQuantityToJudgement :: (MonadTCEnv tcm, LensQuantity q) => q -> tcm a -> tcm a

-- | Apply inverse composition with the given cohesion to the typing
--   context.
applyCohesionToContext :: (MonadTCEnv tcm, LensCohesion m) => m -> tcm a -> tcm a
applyCohesionToContextOnly :: MonadTCEnv tcm => Cohesion -> tcm a -> tcm a

-- | Can we split on arguments of the given cohesion?
splittableCohesion :: (HasOptions m, LensCohesion a) => a -> m Bool

-- | (Conditionally) wake up irrelevant variables and make them relevant.
--   For instance, in an irrelevant function argument otherwise irrelevant
--   variables may be used, so they are awoken before type checking the
--   argument.
--   
--   Also allow the use of irrelevant definitions.
--   
--   This function might also do something for other modalities.
applyModalityToContext :: (MonadTCEnv tcm, LensModality m) => m -> tcm a -> tcm a

-- | (Conditionally) wake up irrelevant variables and make them relevant.
--   For instance, in an irrelevant function argument otherwise irrelevant
--   variables may be used, so they are awoken before type checking the
--   argument.
--   
--   This function might also do something for other modalities, but not
--   for quantities.
--   
--   Precondition: <tt>Modality /= Relevant</tt>
applyModalityToContextOnly :: MonadTCEnv tcm => Modality -> tcm a -> tcm a

-- | Apply the relevance and quantity components of the modality to the
--   modality annotation of the (typing/equality) judgement.
--   
--   Precondition: The relevance component must not be <a>Relevant</a>.
applyModalityToJudgementOnly :: MonadTCEnv tcm => Modality -> tcm a -> tcm a

-- | Like <a>applyModalityToContext</a>, but only act on context (for
--   Relevance) if <tt>--irrelevant-projections</tt>. See issue #2170.
applyModalityToContextFunBody :: (MonadTCM tcm, LensModality r) => r -> tcm a -> tcm a

-- | Wake up irrelevant variables and make them relevant. This is used when
--   type checking terms in a hole, in which case you want to be able to
--   (for instance) infer the type of an irrelevant variable. In the course
--   of type checking an irrelevant function argument
--   <a>applyRelevanceToContext</a> is used instead, which also sets the
--   context relevance to <a>Irrelevant</a>. This is not the right thing to
--   do when type checking interactively in a hole since it also marks all
--   metas created during type checking as irrelevant (issue #2568).
--   
--   Also set the current quantity to 0.
wakeIrrelevantVars :: MonadTCEnv tcm => tcm a -> tcm a

module Agda.TypeChecking.Monad.Closure
enterClosure :: (MonadTCEnv m, ReadTCState m, LensClosure c a) => c -> (a -> m b) -> m b
withClosure :: (MonadTCEnv m, ReadTCState m) => Closure a -> (a -> m b) -> m (Closure b)
mapClosure :: (MonadTCEnv m, ReadTCState m) => (a -> m b) -> Closure a -> m (Closure b)

module Agda.TypeChecking.Monad.Constraints
solvingProblem :: MonadConstraint m => ProblemId -> m a -> m a
solvingProblems :: MonadConstraint m => Set ProblemId -> m a -> m a
isProblemSolved :: (MonadTCEnv m, ReadTCState m) => ProblemId -> m Bool
isProblemCompletelySolved :: (MonadTCEnv m, ReadTCState m) => ProblemId -> m Bool
isProblemSolved' :: (MonadTCEnv m, ReadTCState m) => Bool -> ProblemId -> m Bool
getConstraintsForProblem :: ReadTCState m => ProblemId -> m Constraints

-- | Get the awake constraints
getAwakeConstraints :: ReadTCState m => m Constraints
dropConstraints :: MonadConstraint m => (ProblemConstraint -> Bool) -> m ()

-- | Takes out all constraints matching given filter. Danger! The taken
--   constraints need to be solved or put back at some point.
takeConstraints :: MonadConstraint m => (ProblemConstraint -> Bool) -> m Constraints
putConstraintsToSleep :: MonadConstraint m => (ProblemConstraint -> Bool) -> m ()
putAllConstraintsToSleep :: MonadConstraint m => m ()
data ConstraintStatus
AwakeConstraint :: ConstraintStatus
SleepingConstraint :: ConstraintStatus

-- | Suspend constraints matching the predicate during the execution of the
--   second argument. Caution: held sleeping constraints will not be woken
--   up by events that would normally trigger a wakeup call.
holdConstraints :: (ConstraintStatus -> ProblemConstraint -> Bool) -> TCM a -> TCM a
takeAwakeConstraint :: MonadConstraint m => m (Maybe ProblemConstraint)
takeAwakeConstraint' :: MonadConstraint m => (ProblemConstraint -> Bool) -> m (Maybe ProblemConstraint)
getAllConstraints :: ReadTCState m => m Constraints
withConstraint :: MonadConstraint m => (Constraint -> m a) -> ProblemConstraint -> m a
buildProblemConstraint :: (MonadTCEnv m, ReadTCState m) => Set ProblemId -> Blocker -> Constraint -> m ProblemConstraint
buildProblemConstraint_ :: (MonadTCEnv m, ReadTCState m) => Blocker -> Constraint -> m ProblemConstraint
buildConstraint :: Blocker -> Constraint -> TCM ProblemConstraint

-- | Monad service class containing methods for adding and solving
--   constraints
class (MonadTCEnv m, ReadTCState m, MonadError TCErr m, MonadBlock m, HasOptions m, MonadDebug m) => MonadConstraint m

-- | Unconditionally add the constraint.
addConstraint :: MonadConstraint m => Blocker -> Constraint -> m ()

-- | Add constraint as awake constraint.
addAwakeConstraint :: MonadConstraint m => Blocker -> Constraint -> m ()
solveConstraint :: MonadConstraint m => Constraint -> m ()

-- | Solve awake constraints matching the predicate. If the second argument
--   is True solve constraints even if already <a>isSolvingConstraints</a>.
solveSomeAwakeConstraints :: MonadConstraint m => (ProblemConstraint -> Bool) -> Bool -> m ()
wakeConstraints :: MonadConstraint m => (ProblemConstraint -> WakeUp) -> m ()
stealConstraints :: MonadConstraint m => ProblemId -> m ()
modifyAwakeConstraints :: MonadConstraint m => (Constraints -> Constraints) -> m ()
modifySleepingConstraints :: MonadConstraint m => (Constraints -> Constraints) -> m ()

-- | Add new a constraint
addConstraint' :: Blocker -> Constraint -> TCM ()
addAwakeConstraint' :: Blocker -> Constraint -> TCM ()
addConstraintTo :: Lens' TCState Constraints -> Blocker -> Constraint -> TCM ()

-- | A problem is considered solved if there are no unsolved blocking
--   constraints belonging to it. There's no really good principle for what
--   constraints are blocking and which are not, but the general idea is
--   that nothing bad should happen if you assume a non-blocking constraint
--   is solvable, but it turns out it isn't. For instance, assuming an
--   equality constraint between two types that turns out to be false can
--   lead to ill typed terms in places where we don't expect them.
isBlockingConstraint :: Constraint -> Bool

-- | Start solving constraints
nowSolvingConstraints :: MonadTCEnv m => m a -> m a
isSolvingConstraints :: MonadTCEnv m => m Bool

-- | Add constraint if the action raises a pattern violation
catchConstraint :: MonadConstraint m => Constraint -> m () -> m ()
isInstanceConstraint :: Constraint -> Bool
canDropRecursiveInstance :: (ReadTCState m, HasOptions m) => m Bool
shouldPostponeInstanceSearch :: (ReadTCState m, HasOptions m) => m Bool

-- | Wake constraints matching the given predicate (and aren't instance
--   constraints if <a>shouldPostponeInstanceSearch</a>).
wakeConstraints' :: MonadConstraint m => (ProblemConstraint -> WakeUp) -> m ()
mapAwakeConstraints :: (Constraints -> Constraints) -> TCState -> TCState
mapSleepingConstraints :: (Constraints -> Constraints) -> TCState -> TCState
instance GHC.Show.Show Agda.TypeChecking.Monad.Constraints.ConstraintStatus
instance GHC.Classes.Eq Agda.TypeChecking.Monad.Constraints.ConstraintStatus
instance Agda.TypeChecking.Monad.Constraints.MonadConstraint m => Agda.TypeChecking.Monad.Constraints.MonadConstraint (Control.Monad.Trans.Reader.ReaderT e m)


-- | The scope monad with operations.
module Agda.Syntax.Scope.Monad

-- | To simplify interaction between scope checking and type checking (in
--   particular when chasing imports), we use the same monad.
type ScopeM = TCM
printLocals :: Int -> String -> ScopeM ()
scopeWarning' :: CallStack -> DeclarationWarning' -> ScopeM ()
scopeWarning :: HasCallStack => DeclarationWarning' -> ScopeM ()
isDatatypeModule :: ReadTCState m => ModuleName -> m (Maybe DataOrRecordModule)
getCurrentModule :: ReadTCState m => m ModuleName
setCurrentModule :: MonadTCState m => ModuleName -> m ()
withCurrentModule :: (ReadTCState m, MonadTCState m) => ModuleName -> m a -> m a
withCurrentModule' :: (MonadTrans t, Monad (t ScopeM)) => ModuleName -> t ScopeM a -> t ScopeM a
getNamedScope :: ModuleName -> ScopeM Scope
getCurrentScope :: ScopeM Scope

-- | Create a new module with an empty scope. If the module is not new
--   (e.g. duplicate <tt>import</tt>), don't erase its contents.
--   (<tt>Just</tt> if it is a datatype or record module.)
createModule :: Maybe DataOrRecordModule -> ModuleName -> ScopeM ()

-- | Apply a function to the scope map.
modifyScopes :: (Map ModuleName Scope -> Map ModuleName Scope) -> ScopeM ()

-- | Apply a function to the given scope.
modifyNamedScope :: ModuleName -> (Scope -> Scope) -> ScopeM ()
setNamedScope :: ModuleName -> Scope -> ScopeM ()

-- | Apply a monadic function to the top scope.
modifyNamedScopeM :: ModuleName -> (Scope -> ScopeM (a, Scope)) -> ScopeM a

-- | Apply a function to the current scope.
modifyCurrentScope :: (Scope -> Scope) -> ScopeM ()
modifyCurrentScopeM :: (Scope -> ScopeM (a, Scope)) -> ScopeM a

-- | Apply a function to the public or private name space.
modifyCurrentNameSpace :: NameSpaceId -> (NameSpace -> NameSpace) -> ScopeM ()
setContextPrecedence :: PrecedenceStack -> ScopeM ()
withContextPrecedence :: ReadTCState m => Precedence -> m a -> m a
getLocalVars :: ReadTCState m => m LocalVars
modifyLocalVars :: (LocalVars -> LocalVars) -> ScopeM ()
setLocalVars :: LocalVars -> ScopeM ()

-- | Run a computation without changing the local variables.
withLocalVars :: ScopeM a -> ScopeM a

-- | Run a computation outside some number of local variables and add them
--   back afterwards. This lets you bind variables in the middle of the
--   context and is used when binding generalizable variables (#3735).
outsideLocalVars :: Int -> ScopeM a -> ScopeM a

-- | Check that the newly added variable have unique names.
withCheckNoShadowing :: ScopeM a -> ScopeM a
checkNoShadowing :: LocalVars -> LocalVars -> ScopeM ()
getVarsToBind :: ScopeM LocalVars
addVarToBind :: Name -> LocalVar -> ScopeM ()

-- | After collecting some variable names in the scopeVarsToBind, bind them
--   all simultaneously.
bindVarsToBind :: ScopeM ()
annotateDecls :: ReadTCState m => m [Declaration] -> m Declaration
annotateExpr :: ReadTCState m => m Expr -> m Expr

-- | Create a fresh abstract name from a concrete name.
--   
--   This function is used when we translate a concrete name in a binder.
--   The <a>Range'</a> of the concrete name is saved as the
--   <a>nameBindingSite</a> of the abstract name.
freshAbstractName :: Fixity' -> Name -> ScopeM Name

-- | <pre>
--   freshAbstractName_ = freshAbstractName noFixity'
--   </pre>
freshAbstractName_ :: Name -> ScopeM Name

-- | Create a fresh abstract qualified name.
freshAbstractQName :: Fixity' -> Name -> ScopeM QName
freshAbstractQName' :: Name -> ScopeM QName

-- | Create a concrete name that is not yet in scope. | NOTE: See
--   <tt>chooseName</tt> in
--   <tt>Agda.Syntax.Translation.AbstractToConcrete</tt> for similar logic.
--   | NOTE: See <tt>withName</tt> in
--   <tt>Agda.Syntax.Translation.ReflectedToAbstract</tt> for similar
--   logic.
freshConcreteName :: Range -> Int -> String -> ScopeM Name

-- | Look up the abstract name referred to by a given concrete name.
resolveName :: QName -> ScopeM ResolvedName

-- | Look up the abstract name corresponding to a concrete name of a
--   certain kind and/or from a given set of names. Sometimes we know
--   already that we are dealing with a constructor or pattern synonym
--   (e.g. when we have parsed a pattern). Then, we can ignore conflicting
--   definitions of that name of a different kind. (See issue 822.)
resolveName' :: KindsOfNames -> Maybe (Set Name) -> QName -> ScopeM ResolvedName
tryResolveName :: forall m. (ReadTCState m, HasBuiltins m, MonadError AmbiguousNameReason m) => KindsOfNames -> Maybe (Set Name) -> QName -> m ResolvedName

-- | Test if a given abstract name can appear with a suffix. Currently only
--   true for the names of builtin sorts.
canHaveSuffixTest :: HasBuiltins m => m (QName -> Bool)

-- | Look up a module in the scope.
resolveModule :: QName -> ScopeM AbstractModule

-- | Get the fixity of a not yet bound name.
getConcreteFixity :: Name -> ScopeM Fixity'

-- | Get the polarities of a not yet bound name.
getConcretePolarity :: Name -> ScopeM (Maybe [Occurrence])

-- | Collect the fixity/syntax declarations and polarity pragmas from the
--   list of declarations and store them in the scope.
computeFixitiesAndPolarities :: DoWarn -> [Declaration] -> ScopeM a -> ScopeM a

-- | Get the notation of a name. The name is assumed to be in scope.
getNotation :: QName -> Set Name -> ScopeM NewNotation

-- | Bind a variable.
bindVariable :: BindingSource -> Name -> Name -> ScopeM ()

-- | Temporarily unbind a variable. Used for non-recursive lets.
unbindVariable :: Name -> ScopeM a -> ScopeM a

-- | Bind a defined name. Must not shadow anything.
bindName :: Access -> KindOfName -> Name -> QName -> ScopeM ()
bindName' :: Access -> KindOfName -> NameMetadata -> Name -> QName -> ScopeM ()

-- | Bind a name. Returns the <a>TypeError</a> if exists, but does not
--   throw it.
bindName'' :: Access -> KindOfName -> NameMetadata -> Name -> QName -> ScopeM (Maybe TypeError)

-- | Rebind a name. Use with care! Ulf, 2014-06-29: Currently used to
--   rebind the name defined by an unquoteDecl, which is a
--   <a>QuotableName</a> in the body, but a <a>DefinedName</a> later on.
rebindName :: Access -> KindOfName -> Name -> QName -> ScopeM ()

-- | Bind a module name.
bindModule :: Access -> Name -> ModuleName -> ScopeM ()

-- | Bind a qualified module name. Adds it to the imports field of the
--   scope.
bindQModule :: Access -> QName -> ModuleName -> ScopeM ()

-- | Clear the scope of any no names.
stripNoNames :: ScopeM ()
type WSM = StateT ScopeMemo ScopeM
data ScopeMemo
ScopeMemo :: Ren QName -> Map ModuleName (ModuleName, Bool) -> ScopeMemo
[memoNames] :: ScopeMemo -> Ren QName

-- | Bool: did we copy recursively? We need to track this because we don't
--   copy recursively when creating new modules for reexported functions
--   (issue1985), but we might need to copy recursively later.
[memoModules] :: ScopeMemo -> Map ModuleName (ModuleName, Bool)
memoToScopeInfo :: ScopeMemo -> ScopeCopyInfo

-- | Mark a name as being a copy in the TC state.
copyName :: QName -> QName -> ScopeM ()

-- | Create a new scope with the given name from an old scope. Renames
--   public names in the old scope to match the new name and returns the
--   renamings.
copyScope :: QName -> ModuleName -> Scope -> ScopeM (Scope, ScopeCopyInfo)

-- | Warn about useless fixity declarations in <tt>renaming</tt>
--   directives. Monadic for the sake of error reporting.
checkNoFixityInRenamingModule :: [Renaming] -> ScopeM ()

-- | Check that an import directive doesn't contain repeated names.
verifyImportDirective :: [ImportedName] -> HidingDirective -> RenamingDirective -> ScopeM ()

-- | Apply an import directive and check that all the names mentioned
--   actually exist.
--   
--   Monadic for the sake of error reporting.
applyImportDirectiveM :: QName -> ImportDirective -> Scope -> ScopeM (ImportDirective, Scope)

-- | Translation of <tt>ImportDirective</tt>.
mapImportDir :: (Ord n1, Ord m1) => [ImportedName' (n1, n2) (m1, m2)] -> [ImportedName' (n1, n2) (m1, m2)] -> ImportDirective' n1 m1 -> ImportDirective' n2 m2

-- | A finite map for <tt>ImportedName</tt>s.
data ImportedNameMap n1 n2 m1 m2
ImportedNameMap :: Map n1 n2 -> Map m1 m2 -> ImportedNameMap n1 n2 m1 m2
[inameMap] :: ImportedNameMap n1 n2 m1 m2 -> Map n1 n2
[imoduleMap] :: ImportedNameMap n1 n2 m1 m2 -> Map m1 m2

-- | Create a <a>ImportedNameMap</a>.
importedNameMapFromList :: (Ord n1, Ord m1) => [ImportedName' (n1, n2) (m1, m2)] -> ImportedNameMap n1 n2 m1 m2

-- | Apply a <a>ImportedNameMap</a>.
lookupImportedName :: (Ord n1, Ord m1) => ImportedNameMap n1 n2 m1 m2 -> ImportedName' n1 m1 -> ImportedName' n2 m2

-- | Translation of <tt>Renaming</tt>.
mapRenaming :: (Ord n1, Ord m1) => ImportedNameMap n1 n2 m1 m2 -> ImportedNameMap n1 n2 m1 m2 -> Renaming' n1 m1 -> Renaming' n2 m2
data OpenKind
LetOpenModule :: OpenKind
TopOpenModule :: OpenKind
noGeneralizedVarsIfLetOpen :: OpenKind -> Scope -> Scope

-- | Open a module.
openModule_ :: OpenKind -> QName -> ImportDirective -> ScopeM ImportDirective

-- | Open a module, possibly given an already resolved module name.
openModule :: OpenKind -> Maybe ModuleName -> QName -> ImportDirective -> ScopeM ImportDirective
instance Agda.Syntax.Concrete.Fixity.MonadFixityError Agda.Syntax.Scope.Monad.ScopeM


-- | Flattened scopes.
module Agda.Syntax.Scope.Flat

-- | Flattened scopes.
data FlatScope

-- | Compute a flattened scope. Only include unqualified names or names
--   qualified by modules in the first argument.
flattenScope :: [[Name]] -> ScopeInfo -> FlatScope

-- | Compute all defined names in scope and their fixities/notations. Note
--   that overloaded names (constructors) can have several
--   fixities/notations. Then we <a>mergeNotations</a>. (See issue 1194.)
getDefinedNames :: KindsOfNames -> FlatScope -> [List1 NewNotation]

-- | Compute all names (first component) and operators/notations (second
--   component) in scope.
localNames :: FlatScope -> ScopeM ([QName], [NewNotation])
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Scope.Flat.FlatScope


-- | The parser doesn't know about operators and parses everything as
--   normal function application. This module contains the functions that
--   parses the operators properly. For a stand-alone implementation of
--   this see <tt>src/prototyping/mixfix/old</tt>.
--   
--   It also contains the function that puts parenthesis back given the
--   precedence of the context.
module Agda.Syntax.Concrete.Operators

-- | Parse a list of expressions (typically from a <a>RawApp</a>) into an
--   application.
parseApplication :: List2 Expr -> ScopeM Expr

-- | Parse an expression into a module application (an identifier plus a
--   list of arguments).
parseModuleApplication :: Expr -> ScopeM (QName, [NamedArg Expr])

-- | Parses a left-hand side, and makes sure that it defined the expected
--   name.
parseLHS :: QName -> Pattern -> ScopeM LHSCore

-- | Parses a pattern.
parsePattern :: Pattern -> ScopeM Pattern
parsePatternSyn :: Pattern -> ScopeM Pattern
instance GHC.Show.Show Agda.Syntax.Concrete.Operators.ExprKind
instance GHC.Classes.Eq Agda.Syntax.Concrete.Operators.ExprKind
instance Agda.Syntax.Common.Pretty.Pretty Agda.Syntax.Concrete.Operators.ParseLHS


-- | Lenses for <a>CommandLineOptions</a> and <a>PragmaOptions</a>.
--   
--   Add as needed.
--   
--   Nothing smart happening here.
module Agda.Interaction.Options.Lenses
class LensPragmaOptions a
getPragmaOptions :: LensPragmaOptions a => a -> PragmaOptions
setPragmaOptions :: LensPragmaOptions a => PragmaOptions -> a -> a
mapPragmaOptions :: LensPragmaOptions a => (PragmaOptions -> PragmaOptions) -> a -> a
lensPragmaOptions :: LensPragmaOptions a => Lens' a PragmaOptions
modifyPragmaOptions :: MonadTCState m => (PragmaOptions -> PragmaOptions) -> m ()
class LensVerbosity a
getVerbosity :: LensVerbosity a => a -> Verbosity
setVerbosity :: LensVerbosity a => Verbosity -> a -> a
mapVerbosity :: LensVerbosity a => (Verbosity -> Verbosity) -> a -> a
modifyVerbosity :: MonadTCState m => (Verbosity -> Verbosity) -> m ()
putVerbosity :: MonadTCState m => Verbosity -> m ()
class LensCommandLineOptions a
getCommandLineOptions :: LensCommandLineOptions a => a -> CommandLineOptions
setCommandLineOptions :: LensCommandLineOptions a => CommandLineOptions -> a -> a
mapCommandLineOptions :: LensCommandLineOptions a => (CommandLineOptions -> CommandLineOptions) -> a -> a
modifyCommandLineOptions :: MonadTCState m => (CommandLineOptions -> CommandLineOptions) -> m ()
type SafeMode = Bool
class LensSafeMode a
getSafeMode :: LensSafeMode a => a -> SafeMode
setSafeMode :: LensSafeMode a => SafeMode -> a -> a
mapSafeMode :: LensSafeMode a => (SafeMode -> SafeMode) -> a -> a
modifySafeMode :: MonadTCState m => (SafeMode -> SafeMode) -> m ()
putSafeMode :: MonadTCState m => SafeMode -> m ()

-- | These builtins may use postulates, and are still considered --safe
builtinModulesWithSafePostulates :: Set FilePath

-- | These builtins may not use postulates under --safe. They are not
--   automatically unsafe, but will be if they use an unsafe feature.
builtinModulesWithUnsafePostulates :: Set FilePath
primitiveModules :: Set FilePath
builtinModules :: Set FilePath
isPrimitiveModule :: MonadIO m => FilePath -> m Bool
isBuiltinModule :: MonadIO m => FilePath -> m Bool
isBuiltinModuleWithSafePostulates :: MonadIO m => FilePath -> m Bool
class LensIncludePaths a
getIncludePaths :: LensIncludePaths a => a -> [FilePath]
setIncludePaths :: LensIncludePaths a => [FilePath] -> a -> a
mapIncludePaths :: LensIncludePaths a => ([FilePath] -> [FilePath]) -> a -> a
getAbsoluteIncludePaths :: LensIncludePaths a => a -> [AbsolutePath]
setAbsoluteIncludePaths :: LensIncludePaths a => [AbsolutePath] -> a -> a
mapAbsoluteIncludePaths :: LensIncludePaths a => ([AbsolutePath] -> [AbsolutePath]) -> a -> a
modifyIncludePaths :: MonadTCState m => ([FilePath] -> [FilePath]) -> m ()
putIncludePaths :: MonadTCState m => [FilePath] -> m ()
modifyAbsoluteIncludePaths :: MonadTCState m => ([AbsolutePath] -> [AbsolutePath]) -> m ()
putAbsoluteIncludePaths :: MonadTCState m => [AbsolutePath] -> m ()
type PersistentVerbosity = Verbosity
class LensPersistentVerbosity a
getPersistentVerbosity :: LensPersistentVerbosity a => a -> PersistentVerbosity
setPersistentVerbosity :: LensPersistentVerbosity a => PersistentVerbosity -> a -> a
mapPersistentVerbosity :: LensPersistentVerbosity a => (PersistentVerbosity -> PersistentVerbosity) -> a -> a
modifyPersistentVerbosity :: MonadTCState m => (PersistentVerbosity -> PersistentVerbosity) -> m ()
putPersistentVerbosity :: MonadTCState m => PersistentVerbosity -> m ()
instance Agda.Interaction.Options.Lenses.LensPersistentVerbosity Agda.Interaction.Options.Base.PragmaOptions
instance Agda.Interaction.Options.Lenses.LensPersistentVerbosity Agda.Interaction.Options.Base.CommandLineOptions
instance Agda.Interaction.Options.Lenses.LensPersistentVerbosity Agda.TypeChecking.Monad.Base.PersistentTCState
instance Agda.Interaction.Options.Lenses.LensPersistentVerbosity Agda.TypeChecking.Monad.Base.TCState
instance Agda.Interaction.Options.Lenses.LensIncludePaths Agda.Interaction.Options.Base.CommandLineOptions
instance Agda.Interaction.Options.Lenses.LensIncludePaths Agda.TypeChecking.Monad.Base.PersistentTCState
instance Agda.Interaction.Options.Lenses.LensIncludePaths Agda.TypeChecking.Monad.Base.TCState
instance Agda.Interaction.Options.Lenses.LensSafeMode Agda.Interaction.Options.Base.PragmaOptions
instance Agda.Interaction.Options.Lenses.LensSafeMode Agda.Interaction.Options.Base.CommandLineOptions
instance Agda.Interaction.Options.Lenses.LensSafeMode Agda.TypeChecking.Monad.Base.PersistentTCState
instance Agda.Interaction.Options.Lenses.LensSafeMode Agda.TypeChecking.Monad.Base.TCState
instance Agda.Interaction.Options.Lenses.LensCommandLineOptions Agda.TypeChecking.Monad.Base.PersistentTCState
instance Agda.Interaction.Options.Lenses.LensCommandLineOptions Agda.TypeChecking.Monad.Base.TCState
instance Agda.Interaction.Options.Lenses.LensVerbosity Agda.Interaction.Options.Base.PragmaOptions
instance Agda.Interaction.Options.Lenses.LensVerbosity Agda.TypeChecking.Monad.Base.TCState
instance Agda.Interaction.Options.Lenses.LensPragmaOptions Agda.Interaction.Options.Base.CommandLineOptions
instance Agda.Interaction.Options.Lenses.LensPragmaOptions Agda.TypeChecking.Monad.Base.TCState


-- | Functions which map between module names and file names.
--   
--   Note that file name lookups are cached in the <a>TCState</a>. The code
--   assumes that no Agda source files are added or removed from the
--   include directories while the code is being type checked.
module Agda.Interaction.FindFile

-- | Type aliases for source files and interface files. We may only produce
--   one of these if we know for sure that the file does exist. We can
--   always output an <tt>AbsolutePath</tt> if we are not sure.
newtype SourceFile
SourceFile :: AbsolutePath -> SourceFile
[srcFilePath] :: SourceFile -> AbsolutePath
data InterfaceFile

-- | Converts an Agda file name to the corresponding interface file name.
--   Note that we do not guarantee that the file exists.
toIFile :: SourceFile -> TCM AbsolutePath

-- | Makes an interface file from an AbsolutePath candidate. If the file
--   does not exist, then fail by returning <tt>Nothing</tt>.
mkInterfaceFile :: AbsolutePath -> IO (Maybe InterfaceFile)

-- | Errors which can arise when trying to find a source file.
--   
--   Invariant: All paths are absolute.
data FindError

-- | The file was not found. It should have had one of the given file
--   names.
NotFound :: [SourceFile] -> FindError

-- | Several matching files were found.
--   
--   Invariant: The list of matching files has at least two elements.
Ambiguous :: [SourceFile] -> FindError

-- | Given the module name which the error applies to this function
--   converts a <a>FindError</a> to a <a>TypeError</a>.
findErrorToTypeError :: TopLevelModuleName -> FindError -> TypeError

-- | Finds the source file corresponding to a given top-level module name.
--   The returned paths are absolute.
--   
--   Raises an error if the file cannot be found.
findFile :: TopLevelModuleName -> TCM SourceFile

-- | Tries to find the source file corresponding to a given top-level
--   module name. The returned paths are absolute.
--   
--   SIDE EFFECT: Updates <a>stModuleToSource</a>.
findFile' :: TopLevelModuleName -> TCM (Either FindError SourceFile)

-- | A variant of <a>findFile'</a> which does not require <a>TCMT</a>.
findFile'' :: [AbsolutePath] -> TopLevelModuleName -> ModuleToSource -> IO (Either FindError SourceFile, ModuleToSource)

-- | Finds the interface file corresponding to a given top-level module
--   file. The returned paths are absolute.
--   
--   Raises <a>Nothing</a> if the interface file cannot be found.
findInterfaceFile' :: SourceFile -> TCM (Maybe InterfaceFile)

-- | Finds the interface file corresponding to a given top-level module
--   file. The returned paths are absolute.
--   
--   Raises an error if the source file cannot be found, and returns
--   <a>Nothing</a> if the source file can be found but not the interface
--   file.
findInterfaceFile :: TopLevelModuleName -> TCM (Maybe InterfaceFile)

-- | Ensures that the module name matches the file name. The file
--   corresponding to the module name (according to the include path) has
--   to be the same as the given file name.
checkModuleName :: TopLevelModuleName -> SourceFile -> Maybe TopLevelModuleName -> TCM ()

-- | Computes the module name of the top-level module in the given file.
--   
--   If no top-level module name is given, then an attempt is made to use
--   the file name as a module name.
moduleName :: AbsolutePath -> Module -> TCM TopLevelModuleName
rootNameModule :: AbsolutePath -> String
replaceModuleExtension :: String -> AbsolutePath -> AbsolutePath
instance GHC.Show.Show Agda.Interaction.FindFile.SourceFile
instance GHC.Classes.Ord Agda.Interaction.FindFile.SourceFile
instance GHC.Classes.Eq Agda.Interaction.FindFile.SourceFile
instance GHC.Show.Show Agda.Interaction.FindFile.FindError
instance Agda.Syntax.Common.Pretty.Pretty Agda.Interaction.FindFile.InterfaceFile
instance Agda.Syntax.Common.Pretty.Pretty Agda.Interaction.FindFile.SourceFile

module Agda.TypeChecking.Serialise.Instances.Common

-- | Ranges that should be serialised properly.
newtype SerialisedRange
SerialisedRange :: Range -> SerialisedRange
[underlyingRange] :: SerialisedRange -> Range
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Serialise.Instances.Common.SerialisedRange
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Abstract.Name.Name
instance Agda.TypeChecking.Serialise.Base.EmbPrj GHC.Base.String
instance Agda.TypeChecking.Serialise.Base.EmbPrj Data.Text.Internal.Lazy.Text
instance Agda.TypeChecking.Serialise.Base.EmbPrj Data.Text.Internal.Text
instance Agda.TypeChecking.Serialise.Base.EmbPrj GHC.Num.Integer.Integer
instance Agda.TypeChecking.Serialise.Base.EmbPrj GHC.Word.Word64
instance Agda.TypeChecking.Serialise.Base.EmbPrj GHC.Int.Int32
instance Agda.TypeChecking.Serialise.Base.EmbPrj GHC.Types.Int
instance Agda.TypeChecking.Serialise.Base.EmbPrj GHC.Types.Char
instance Agda.TypeChecking.Serialise.Base.EmbPrj GHC.Types.Double
instance Agda.TypeChecking.Serialise.Base.EmbPrj GHC.Base.Void
instance Agda.TypeChecking.Serialise.Base.EmbPrj ()
instance (Agda.TypeChecking.Serialise.Base.EmbPrj a, Agda.TypeChecking.Serialise.Base.EmbPrj b) => Agda.TypeChecking.Serialise.Base.EmbPrj (a, b)
instance (Agda.TypeChecking.Serialise.Base.EmbPrj a, Agda.TypeChecking.Serialise.Base.EmbPrj b) => Agda.TypeChecking.Serialise.Base.EmbPrj (Data.Strict.Tuple.Pair a b)
instance (Agda.TypeChecking.Serialise.Base.EmbPrj a, Agda.TypeChecking.Serialise.Base.EmbPrj b, Agda.TypeChecking.Serialise.Base.EmbPrj c) => Agda.TypeChecking.Serialise.Base.EmbPrj (a, b, c)
instance (Agda.TypeChecking.Serialise.Base.EmbPrj a, Agda.TypeChecking.Serialise.Base.EmbPrj b) => Agda.TypeChecking.Serialise.Base.EmbPrj (Data.Either.Either a b)
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (GHC.Maybe.Maybe a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Data.Strict.Maybe.Maybe a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj GHC.Types.Bool
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.FileType
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Cubical
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Language
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Position.Position' a)
instance (Agda.TypeChecking.Serialise.Base.EmbPrj a, Data.Typeable.Internal.Typeable b) => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Utils.WithDefault.WithDefault' a b)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.TopLevelModuleName.TopLevelModuleName
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj [a]
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Utils.List1.List1 a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Utils.List2.List2 a)
instance (Agda.TypeChecking.Serialise.Base.EmbPrj k, Agda.TypeChecking.Serialise.Base.EmbPrj v, Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Utils.BiMap.Tag v)) => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Utils.BiMap.BiMap k v)
instance (GHC.Classes.Ord a, Agda.TypeChecking.Serialise.Base.EmbPrj a, Agda.TypeChecking.Serialise.Base.EmbPrj b) => Agda.TypeChecking.Serialise.Base.EmbPrj (Data.Map.Internal.Map a b)
instance (GHC.Classes.Ord a, Agda.TypeChecking.Serialise.Base.EmbPrj a) => Agda.TypeChecking.Serialise.Base.EmbPrj (Data.Set.Internal.Set a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Data.IntSet.Internal.IntSet
instance Data.Typeable.Internal.Typeable a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Utils.SmallSet.SmallSet a)
instance (GHC.Classes.Ord a, Agda.TypeChecking.Serialise.Base.EmbPrj a, Agda.TypeChecking.Serialise.Base.EmbPrj b) => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Utils.Trie.Trie a b)
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Data.Sequence.Internal.Seq a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Position.Interval' a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Position.RangeFile
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Position.Range
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.KeywordRange.KwRange
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Concrete.Name.Name
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Concrete.Name.NamePart
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Concrete.Name.NameInScope
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Concrete.Name.QName
instance (Agda.TypeChecking.Serialise.Base.EmbPrj a, Agda.TypeChecking.Serialise.Base.EmbPrj b) => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Common.ImportedName' a b)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Associativity
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.FixityLevel
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Fixity
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Fixity'
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.BoundVariablePosition
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.NotationPart
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.MetaId
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.ProblemId
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Abstract.Name.QName
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Abstract.Name.AmbiguousQName
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Abstract.Name.ModuleName
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Concrete.FieldAssignment' a)
instance (Agda.TypeChecking.Serialise.Base.EmbPrj s, Agda.TypeChecking.Serialise.Base.EmbPrj t) => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Common.Named s t)
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Common.Ranged a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.ArgInfo
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.TopLevelModuleName.Boot.ModuleNameHash
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.NameId
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.OpaqueId
instance (GHC.Classes.Eq k, Data.Hashable.Class.Hashable k, Agda.TypeChecking.Serialise.Base.EmbPrj k, Agda.TypeChecking.Serialise.Base.EmbPrj v) => Agda.TypeChecking.Serialise.Base.EmbPrj (Data.HashMap.Internal.HashMap k v)
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Common.WithHiding a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Common.HasEta' a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.PatternOrCopattern
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.OverlapMode
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Aspect.Induction
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Hiding
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Q0Origin
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Q1Origin
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.QωOrigin
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Quantity
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Cohesion
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Modality
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Relevance
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Annotation
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Lock
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Origin
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Common.WithOrigin a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.FreeVariables
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.ConOrigin
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.ProjOrigin
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Literal.Literal
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.IsAbstract
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.IsOpaque
instance Agda.TypeChecking.Serialise.Base.EmbPrj GHC.Stack.Types.SrcLoc
instance Agda.TypeChecking.Serialise.Base.EmbPrj GHC.Stack.Types.CallStack
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Utils.Impossible.Impossible
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.ExpandedEllipsis
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Interaction.Library.Base.OptionsPragma
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Builtin.BuiltinId
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Builtin.PrimitiveId
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Builtin.SomeBuiltin
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.IsInstance
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Common.RecordDirectives' a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Concrete.RecordDirective

module Agda.TypeChecking.Serialise.Instances.Highlighting
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Interaction.Highlighting.Range.Range
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Aspect.NameKind
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Aspect.Aspect
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Aspect.OtherAspect
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Aspect.Aspects
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Aspect.DefinitionSite
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Utils.RangeMap.RangeMap a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Aspect.TokenBased

module Agda.TypeChecking.Serialise.Instances.Abstract
data AbsNameWithFixity
AbsNameWithFixity :: Fixity -> QName -> KindOfName -> WhyInScope -> NameMetadata -> AbsNameWithFixity
toAbsName :: AbsNameWithFixity -> AbstractName
fromAbsName :: AbstractName -> AbsNameWithFixity
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Serialise.Instances.Abstract.AbsNameWithFixity
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Abstract.BindName
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Scope.Base.Scope
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Scope.Base.DataOrRecordModule
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Scope.Base.NameSpaceId
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Access
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Scope.Base.NameSpace
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Scope.Base.WhyInScope
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Scope.Base.AbstractName
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Scope.Base.NameMetadata
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Abstract.Name.Suffix
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Scope.Base.AbstractModule
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Scope.Base.KindOfName
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Scope.Base.BindingSource
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Scope.Base.LocalVar
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Info.ConPatInfo
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Info.ConPatLazy
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Abstract.Pattern' a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Fixity.ParenPreference
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Fixity.Precedence
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Scope.Base.ScopeInfo
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Scope.Base.NameOrModule

module Agda.TypeChecking.Monad.Options

-- | Sets the pragma options. Checks for unsafe combinations.
setPragmaOptions :: PragmaOptions -> TCM ()

-- | Check that that you don't turn on inconsistent options. For instance,
--   if --a implies --b and you have both --a and --no-b. Only warn for
--   things that have changed compared to the old options.
checkPragmaOptionConsistency :: PragmaOptions -> PragmaOptions -> TCM ()

-- | Sets the command line options (both persistent and pragma options are
--   updated).
--   
--   Relative include directories are made absolute with respect to the
--   current working directory. If the include directories have changed
--   then the state is reset (partly, see <a>setIncludeDirs</a>).
--   
--   An empty list of relative include directories (<tt><a>Left</a>
--   []</tt>) is interpreted as <tt>["."]</tt>.
setCommandLineOptions :: CommandLineOptions -> TCM ()
setCommandLineOptions' :: AbsolutePath -> CommandLineOptions -> TCM ()
libToTCM :: LibM a -> TCM a

-- | Returns the library files for a given file.
--   
--   Nothing is returned if <a>optUseLibs</a> is <a>False</a>.
--   
--   An error is raised if <a>optUseLibs</a> is <a>True</a> and a library
--   file is located too far down the directory hierarchy (see
--   <a>checkLibraryFileNotTooFarDown</a>).
getAgdaLibFiles :: AbsolutePath -> TopLevelModuleName -> TCM [AgdaLibFile]

-- | Returns potential library files for a file without a known top-level
--   module name.
--   
--   Once the top-level module name is known one can use
--   <a>checkLibraryFileNotTooFarDown</a> to check that the potential
--   library files were not located too far down the directory hierarchy.
--   
--   Nothing is returned if <a>optUseLibs</a> is <a>False</a>.
getAgdaLibFilesWithoutTopLevelModuleName :: AbsolutePath -> TCM [AgdaLibFile]

-- | Checks that a library file for the module <tt>A.B.C</tt> (say) in the
--   directory <tt>dir<i>A</i>B</tt> is located at least two directories
--   above the file (not in <tt>dir/A</tt> or <tt>dir<i>A</i>B</tt>).
checkLibraryFileNotTooFarDown :: TopLevelModuleName -> AgdaLibFile -> TCM ()

-- | Returns the library options for a given file.
getLibraryOptions :: AbsolutePath -> TopLevelModuleName -> TCM [OptionsPragma]
setLibraryPaths :: AbsolutePath -> CommandLineOptions -> TCM CommandLineOptions
setLibraryIncludes :: CommandLineOptions -> TCM CommandLineOptions
addDefaultLibraries :: AbsolutePath -> CommandLineOptions -> TCM CommandLineOptions
addTrustedExecutables :: CommandLineOptions -> TCM CommandLineOptions

-- | Set pragma options without checking for consistency.
setOptionsFromPragma :: OptionsPragma -> TCM ()

-- | Set pragma options and check them for consistency.
checkAndSetOptionsFromPragma :: OptionsPragma -> TCM ()
setOptionsFromPragma' :: Bool -> OptionsPragma -> TCM ()

-- | Disable display forms.
enableDisplayForms :: MonadTCEnv m => m a -> m a

-- | Disable display forms.
disableDisplayForms :: MonadTCEnv m => m a -> m a

-- | Check if display forms are enabled.
displayFormsEnabled :: MonadTCEnv m => m Bool

-- | Gets the include directories.
--   
--   Precondition: <a>optAbsoluteIncludePaths</a> must be nonempty (i.e.
--   <a>setCommandLineOptions</a> must have run).
getIncludeDirs :: HasOptions m => m [AbsolutePath]

-- | Makes the given directories absolute and stores them as include
--   directories.
--   
--   If the include directories change, then the state is reset
--   (completely, except for the include directories and some other
--   things).
--   
--   An empty list is interpreted as <tt>["."]</tt>.
setIncludeDirs :: [FilePath] -> AbsolutePath -> TCM ()
isPropEnabled :: HasOptions m => m Bool
isLevelUniverseEnabled :: HasOptions m => m Bool
isTwoLevelEnabled :: HasOptions m => m Bool
hasUniversePolymorphism :: HasOptions m => m Bool
showImplicitArguments :: HasOptions m => m Bool
showGeneralizedArguments :: HasOptions m => m Bool
showIrrelevantArguments :: HasOptions m => m Bool
showIdentitySubstitutions :: HasOptions m => m Bool

-- | Switch on printing of implicit and irrelevant arguments. E.g. for
--   reification in with-function generation.
--   
--   Restores all <a>PragmaOptions</a> after completion. Thus, do not
--   attempt to make persistent <a>PragmaOptions</a> changes in a
--   <a>withShowAllArguments</a> bracket.
withShowAllArguments :: ReadTCState m => m a -> m a
withShowAllArguments' :: ReadTCState m => Bool -> m a -> m a
withoutPrintingGeneralization :: ReadTCState m => m a -> m a

-- | Change <a>PragmaOptions</a> for a computation and restore afterwards.
withPragmaOptions :: ReadTCState m => (PragmaOptions -> PragmaOptions) -> m a -> m a
positivityCheckEnabled :: HasOptions m => m Bool
typeInType :: HasOptions m => m Bool
etaEnabled :: HasOptions m => m Bool
maxInstanceSearchDepth :: HasOptions m => m Int
maxInversionDepth :: HasOptions m => m Int

-- | Returns the <a>Language</a> currently in effect.
getLanguage :: HasOptions m => m Language

module Agda.TypeChecking.Monad.Signature

-- | If the first argument is <tt><a>Erased</a> something</tt>, then hard
--   compile-time mode is enabled when the continuation is run.
setHardCompileTimeModeIfErased :: Erased -> TCM a -> TCM a

-- | If the quantity is "erased", then hard compile-time mode is enabled
--   when the continuation is run.
--   
--   Precondition: The quantity must not be <tt><a>Quantity1</a>
--   something</tt>.
setHardCompileTimeModeIfErased' :: LensQuantity q => q -> TCM a -> TCM a

-- | Use run-time mode in the continuation unless the current mode is the
--   hard compile-time mode.
setRunTimeModeUnlessInHardCompileTimeMode :: TCM a -> TCM a

-- | Use hard compile-time mode in the continuation if the first argument
--   is <tt><a>Erased</a> something</tt>. Use run-time mode if the first
--   argument is <tt><a>NotErased</a> something</tt> and the current mode
--   is not hard compile-time mode.
setModeUnlessInHardCompileTimeMode :: Erased -> TCM a -> TCM a

-- | Warn if the user explicitly wrote @<tt>ω</tt> or @<tt>plenty</tt> but
--   the current mode is the hard compile-time mode.
warnForPlentyInHardCompileTimeMode :: Erased -> TCM ()

-- | Add a constant to the signature. Lifts the definition to top level.
addConstant :: QName -> Definition -> TCM ()

-- | A combination of <a>addConstant</a> and <a>defaultDefn</a>. The
--   <a>Language</a> does not need to be supplied.
addConstant' :: QName -> ArgInfo -> QName -> Type -> Defn -> TCM ()

-- | Set termination info of a defined function symbol.
setTerminates :: MonadTCState m => QName -> Bool -> m ()

-- | Set CompiledClauses of a defined function symbol.
setCompiledClauses :: QName -> CompiledClauses -> TCM ()

-- | Set SplitTree of a defined function symbol.
setSplitTree :: QName -> SplitTree -> TCM ()

-- | Modify the clauses of a function.
modifyFunClauses :: QName -> ([Clause] -> [Clause]) -> TCM ()

-- | Lifts clauses to the top-level and adds them to definition. Also
--   adjusts the <tt>funCopatternLHS</tt> field if necessary.
addClauses :: (MonadConstraint m, MonadTCState m) => QName -> [Clause] -> m ()
mkPragma :: String -> TCM CompilerPragma

-- | Add a compiler pragma `{-# COMPILE <a>backend</a> <a>name</a>
--   <a>text</a> #-}`
addPragma :: BackendName -> QName -> String -> TCM ()
getUniqueCompilerPragma :: BackendName -> QName -> TCM (Maybe CompilerPragma)
setFunctionFlag :: FunctionFlag -> Bool -> QName -> TCM ()
markStatic :: QName -> TCM ()
markInline :: Bool -> QName -> TCM ()
markInjective :: QName -> TCM ()
markFirstOrder :: QName -> TCM ()
unionSignatures :: [Signature] -> Signature

-- | Add a section to the signature.
--   
--   The current context will be stored as the cumulative module parameters
--   for this section.
addSection :: ModuleName -> TCM ()

-- | Sets the checkpoint for the given module to the current checkpoint.
setModuleCheckpoint :: ModuleName -> TCM ()

-- | Get a section.
--   
--   Why Maybe? The reason is that we look up all prefixes of a module to
--   compute number of parameters, and for hierarchical top-level modules,
--   A.B.C say, A and A.B do not exist.
getSection :: (Functor m, ReadTCState m) => ModuleName -> m (Maybe Section)

-- | Lookup a section telescope.
--   
--   If it doesn't exist, like in hierarchical top-level modules, the
--   section telescope is empty.
lookupSection :: (Functor m, ReadTCState m) => ModuleName -> m Telescope

-- | Add display forms for a name <tt>f</tt> copied by a module
--   application. Essentially if <tt>f</tt> can reduce to
--   
--   <pre>
--   λ xs → A.B.C.f vs
--   </pre>
--   
--   by unfolding module application copies (<a>defCopy</a>), then we add a
--   display form
--   
--   <pre>
--   A.B.C.f vs ==&gt; f xs
--   </pre>
addDisplayForms :: QName -> TCM ()

-- | Module application (followed by module parameter abstraction).
applySection :: ModuleName -> Telescope -> ModuleName -> Args -> ScopeCopyInfo -> TCM ()
applySection' :: ModuleName -> Telescope -> ModuleName -> Args -> ScopeCopyInfo -> TCM ()

-- | Add a display form to a definition (could be in this or imported
--   signature).
addDisplayForm :: QName -> DisplayForm -> TCM ()
isLocal :: ReadTCState m => QName -> m Bool
getDisplayForms :: (HasConstInfo m, ReadTCState m) => QName -> m [LocalDisplayForm]
hasDisplayForms :: (HasConstInfo m, ReadTCState m) => QName -> m Bool

-- | Find all names used (recursively) by display forms of a given name.
chaseDisplayForms :: QName -> TCM (Set QName)

-- | Check if a display form is looping.
hasLoopingDisplayForm :: QName -> TCM Bool
canonicalName :: HasConstInfo m => QName -> m QName
sameDef :: HasConstInfo m => QName -> QName -> m (Maybe QName)

-- | Does the given constructor come from a single-constructor type?
--   
--   Precondition: The name has to refer to a constructor.
singleConstructorType :: QName -> TCM Bool

-- | Signature lookup errors.
data SigError

-- | The name is not in the signature; default error message.
SigUnknown :: String -> SigError

-- | The name is not available, since it is abstract.
SigAbstract :: SigError

-- | The name is not available because it was defined in Cubical Agda, but
--   the current language is Erased Cubical Agda, and <tt>--erasure</tt> is
--   not active.
SigCubicalNotErasure :: SigError

-- | Generates an error message corresponding to
--   <a>SigCubicalNotErasure</a> for a given <a>QName</a>.
notSoPrettySigCubicalNotErasure :: QName -> String

-- | Generates an error message corresponding to
--   <a>SigCubicalNotErasure</a> for a given <a>QName</a>.
prettySigCubicalNotErasure :: MonadPretty m => QName -> m Doc

-- | An eliminator for <a>SigError</a>. All constructors except for
--   <a>SigAbstract</a> are assumed to be impossible.
sigError :: (HasCallStack, MonadDebug m) => m a -> SigError -> m a
class (Functor m, Applicative m, MonadFail m, HasOptions m, MonadDebug m, MonadTCEnv m) => HasConstInfo m

-- | Lookup the definition of a name. The result is a closed thing, all
--   free variables have been abstracted over.
getConstInfo :: HasConstInfo m => QName -> m Definition

-- | Version that reports exceptions:
getConstInfo' :: HasConstInfo m => QName -> m (Either SigError Definition)

-- | Lookup the rewrite rules with the given head symbol.
getRewriteRulesFor :: HasConstInfo m => QName -> m RewriteRules

-- | Version that reports exceptions:
getConstInfo' :: (HasConstInfo m, HasConstInfo n, MonadTrans t, m ~ t n) => QName -> m (Either SigError Definition)

-- | Lookup the rewrite rules with the given head symbol.
getRewriteRulesFor :: (HasConstInfo m, HasConstInfo n, MonadTrans t, m ~ t n) => QName -> m RewriteRules

-- | The computation <a>getConstInfo</a> sometimes tweaks the returned
--   <a>Definition</a>, depending on the current <a>Language</a> and the
--   <a>Language</a> of the <a>Definition</a>. This variant of
--   <a>getConstInfo</a> does not perform any tweaks.
getOriginalConstInfo :: (ReadTCState m, HasConstInfo m) => QName -> m Definition
defaultGetRewriteRulesFor :: (ReadTCState m, MonadTCEnv m) => QName -> m RewriteRules

-- | Get the original name of the projection (the current one could be from
--   a module application).
getOriginalProjection :: HasConstInfo m => QName -> m QName
defaultGetConstInfo :: (HasOptions m, MonadDebug m, MonadTCEnv m) => TCState -> TCEnv -> QName -> m (Either SigError Definition)
getConInfo :: HasConstInfo m => ConHead -> m Definition

-- | Look up the polarity of a definition.
getPolarity :: HasConstInfo m => QName -> m [Polarity]

-- | Look up polarity of a definition and compose with polarity represented
--   by <a>Comparison</a>.
getPolarity' :: HasConstInfo m => Comparison -> QName -> m [Polarity]

-- | Set the polarity of a definition.
setPolarity :: (MonadTCState m, MonadDebug m) => QName -> [Polarity] -> m ()

-- | Look up the forced arguments of a definition.
getForcedArgs :: HasConstInfo m => QName -> m [IsForced]

-- | Get argument occurrence info for argument <tt>i</tt> of definition
--   <tt>d</tt> (never fails).
getArgOccurrence :: QName -> Nat -> TCM Occurrence

-- | Sets the <a>defArgOccurrences</a> for the given identifier (which
--   should already exist in the signature).
setArgOccurrences :: MonadTCState m => QName -> [Occurrence] -> m ()
modifyArgOccurrences :: MonadTCState m => QName -> ([Occurrence] -> [Occurrence]) -> m ()
setTreeless :: QName -> TTerm -> TCM ()
setCompiledArgUse :: QName -> [ArgUsage] -> TCM ()
getCompiled :: HasConstInfo m => QName -> m (Maybe Compiled)

-- | Returns a list of length <a>conArity</a>. If no erasure analysis has
--   been performed yet, this will be a list of <a>False</a>s.
getErasedConArgs :: HasConstInfo m => QName -> m [Bool]
setErasedConArgs :: QName -> [Bool] -> TCM ()
getTreeless :: HasConstInfo m => QName -> m (Maybe TTerm)
getCompiledArgUse :: HasConstInfo m => QName -> m (Maybe [ArgUsage])

-- | add data constructors to a datatype
addDataCons :: QName -> [QName] -> TCM ()

-- | Get the mutually recursive identifiers of a symbol from the signature.
getMutual :: QName -> TCM (Maybe [QName])

-- | Get the mutually recursive identifiers from a <a>Definition</a>.
getMutual_ :: Defn -> Maybe [QName]

-- | Set the mutually recursive identifiers.
--   
--   TODO: This produces data of quadratic size (which has to be processed
--   upon serialization). Presumably qs is usually short, but in some cases
--   (for instance for generated code) it may be long. It would be better
--   to assign a unique identifier to each SCC, and store the names
--   separately.
setMutual :: QName -> [QName] -> TCM ()

-- | Check whether two definitions are mutually recursive.
mutuallyRecursive :: QName -> QName -> TCM Bool

-- | A function<i>data</i>record definition is nonRecursive if it is not
--   even mutually recursive with itself.
definitelyNonRecursive_ :: Defn -> Bool

-- | Get the number of parameters to the current module.
getCurrentModuleFreeVars :: TCM Nat
getDefModule :: HasConstInfo m => QName -> m (Either SigError ModuleName)

-- | Compute the number of free variables of a defined name. This is the
--   sum of number of parameters shared with the current module and the
--   number of anonymous variables (if the name comes from a let-bound
--   module).
getDefFreeVars :: (Functor m, Applicative m, ReadTCState m, MonadTCEnv m) => QName -> m Nat
freeVarsToApply :: (Functor m, HasConstInfo m, HasOptions m, ReadTCState m, MonadTCEnv m, MonadDebug m) => QName -> m Args
getModuleFreeVars :: (Functor m, Applicative m, MonadTCEnv m, ReadTCState m) => ModuleName -> m Nat

-- | Compute the context variables to apply a definition to.
--   
--   We have to insert the module telescope of the common prefix of the
--   current module and the module where the definition comes from.
--   (Properly raised to the current context.)
--   
--   Example: <tt> module M₁ Γ where module M₁ Δ where f = ... module M₃ Θ
--   where ... M₁.M₂.f [insert Γ raised by Θ] </tt>
moduleParamsToApply :: (Functor m, Applicative m, HasOptions m, MonadTCEnv m, ReadTCState m, MonadDebug m) => ModuleName -> m Args

-- | Unless all variables in the context are module parameters, create a
--   fresh module to capture the non-module parameters. Used when unquoting
--   to make sure generated definitions work properly.
inFreshModuleIfFreeParams :: TCM a -> TCM a

-- | Instantiate a closed definition with the correct part of the current
--   context.
instantiateDef :: (Functor m, HasConstInfo m, HasOptions m, ReadTCState m, MonadTCEnv m, MonadDebug m) => Definition -> m Definition
instantiateRewriteRule :: (Functor m, HasConstInfo m, HasOptions m, ReadTCState m, MonadTCEnv m, MonadDebug m) => RewriteRule -> m RewriteRule
instantiateRewriteRules :: (Functor m, HasConstInfo m, HasOptions m, ReadTCState m, MonadTCEnv m, MonadDebug m) => RewriteRules -> m RewriteRules

-- | Return the abstract view of a definition, <i>regardless</i> of whether
--   the definition would be treated abstractly.
alwaysMakeAbstract :: Definition -> Maybe Definition

-- | Enter abstract mode. Abstract definition in the current module are
--   transparent.
inAbstractMode :: MonadTCEnv m => m a -> m a

-- | Not in abstract mode. All abstract definitions are opaque.
inConcreteMode :: MonadTCEnv m => m a -> m a

-- | Ignore abstract mode. All abstract definitions are transparent.
ignoreAbstractMode :: MonadTCEnv m => m a -> m a

-- | Go under the given opaque block. The unfolding set will turn opaque
--   definitions transparent.
underOpaqueId :: MonadTCEnv m => OpaqueId -> m a -> m a

-- | Outside of any opaque blocks.
notUnderOpaque :: MonadTCEnv m => m a -> m a

-- | Enter the reducibility environment associated with a definition: The
--   environment will have the same concreteness as the name, and we will
--   be in the opaque block enclosing the name, if any.
inConcreteOrAbstractMode :: (MonadTCEnv m, HasConstInfo m) => QName -> (Definition -> m a) -> m a

-- | Get type of a constant, instantiated to the current context.
typeOfConst :: (HasConstInfo m, ReadTCState m) => QName -> m Type

-- | Get relevance of a constant.
relOfConst :: HasConstInfo m => QName -> m Relevance

-- | Get modality of a constant.
modalityOfConst :: HasConstInfo m => QName -> m Modality

-- | The number of dropped parameters for a definition. 0 except for
--   projection(-like) functions and constructors.
droppedPars :: Definition -> Int

-- | Is it the name of a record projection?
isProjection :: HasConstInfo m => QName -> m (Maybe Projection)
isProjection_ :: Defn -> Maybe Projection

-- | Is it the name of a non-irrelevant record projection?
isRelevantProjection :: HasConstInfo m => QName -> m (Maybe Projection)
isRelevantProjection_ :: Definition -> Maybe Projection

-- | Is it a function marked STATIC?
isStaticFun :: Defn -> Bool

-- | Is it a function marked INLINE?
isInlineFun :: Defn -> Bool

-- | Returns <tt>True</tt> if we are dealing with a proper projection,
--   i.e., not a projection-like function nor a record field value
--   (projection applied to argument).
isProperProjection :: Defn -> Bool

-- | Number of dropped initial arguments of a projection(-like) function.
projectionArgs :: Definition -> Int

-- | Check whether a definition uses copatterns.
usesCopatterns :: (HasConstInfo m, HasBuiltins m) => QName -> m Bool

-- | Apply a function <tt>f</tt> to its first argument, producing the
--   proper postfix projection if <tt>f</tt> is a projection which is not
--   irrelevant.
applyDef :: HasConstInfo m => ProjOrigin -> QName -> Arg Term -> m Term
instance Agda.TypeChecking.Monad.Signature.HasConstInfo (Agda.TypeChecking.Monad.Base.TCMT GHC.Types.IO)
instance Agda.TypeChecking.Monad.Signature.HasConstInfo m => Agda.TypeChecking.Monad.Signature.HasConstInfo (Agda.Utils.Update.ChangeT m)
instance Agda.TypeChecking.Monad.Signature.HasConstInfo m => Agda.TypeChecking.Monad.Signature.HasConstInfo (Control.Monad.Trans.Except.ExceptT err m)
instance Agda.TypeChecking.Monad.Signature.HasConstInfo m => Agda.TypeChecking.Monad.Signature.HasConstInfo (Control.Monad.Trans.Identity.IdentityT m)
instance Agda.TypeChecking.Monad.Signature.HasConstInfo m => Agda.TypeChecking.Monad.Signature.HasConstInfo (Agda.Utils.ListT.ListT m)
instance Agda.TypeChecking.Monad.Signature.HasConstInfo m => Agda.TypeChecking.Monad.Signature.HasConstInfo (Control.Monad.Trans.Maybe.MaybeT m)
instance Agda.TypeChecking.Monad.Signature.HasConstInfo m => Agda.TypeChecking.Monad.Signature.HasConstInfo (Control.Monad.Trans.Reader.ReaderT r m)
instance Agda.TypeChecking.Monad.Signature.HasConstInfo m => Agda.TypeChecking.Monad.Signature.HasConstInfo (Control.Monad.Trans.State.Lazy.StateT s m)
instance (GHC.Base.Monoid w, Agda.TypeChecking.Monad.Signature.HasConstInfo m) => Agda.TypeChecking.Monad.Signature.HasConstInfo (Control.Monad.Trans.Writer.Lazy.WriterT w m)
instance Agda.TypeChecking.Monad.Signature.HasConstInfo m => Agda.TypeChecking.Monad.Signature.HasConstInfo (Agda.TypeChecking.Monad.Base.BlockT m)


-- | A typeclass collecting all <a>pure</a> typechecking operations | (i.e.
--   ones that do not modify the typechecking state, throw or | catch
--   errors, or do IO other than debug printing).
module Agda.TypeChecking.Monad.Pure
class (HasBuiltins m, HasConstInfo m, MonadAddContext m, MonadDebug m, MonadReduce m, MonadTCEnv m, ReadTCState m) => PureTCM m
instance Agda.TypeChecking.Monad.Pure.PureTCM Agda.TypeChecking.Monad.Base.TCM
instance Agda.TypeChecking.Monad.Pure.PureTCM m => Agda.TypeChecking.Monad.Pure.PureTCM (Agda.TypeChecking.Monad.Base.BlockT m)
instance Agda.TypeChecking.Monad.Pure.PureTCM m => Agda.TypeChecking.Monad.Pure.PureTCM (Agda.Utils.Update.ChangeT m)
instance Agda.TypeChecking.Monad.Pure.PureTCM m => Agda.TypeChecking.Monad.Pure.PureTCM (Control.Monad.Trans.Except.ExceptT e m)
instance Agda.TypeChecking.Monad.Pure.PureTCM m => Agda.TypeChecking.Monad.Pure.PureTCM (Control.Monad.Trans.Identity.IdentityT m)
instance Agda.TypeChecking.Monad.Pure.PureTCM m => Agda.TypeChecking.Monad.Pure.PureTCM (Agda.Utils.ListT.ListT m)
instance Agda.TypeChecking.Monad.Pure.PureTCM m => Agda.TypeChecking.Monad.Pure.PureTCM (Control.Monad.Trans.Maybe.MaybeT m)
instance Agda.TypeChecking.Monad.Pure.PureTCM m => Agda.TypeChecking.Monad.Pure.PureTCM (Control.Monad.Trans.Reader.ReaderT r m)
instance (Agda.TypeChecking.Monad.Pure.PureTCM m, GHC.Base.Monoid w) => Agda.TypeChecking.Monad.Pure.PureTCM (Control.Monad.Trans.Writer.Lazy.WriterT w m)
instance Agda.TypeChecking.Monad.Pure.PureTCM m => Agda.TypeChecking.Monad.Pure.PureTCM (Control.Monad.Trans.State.Lazy.StateT s m)

module Agda.TypeChecking.Monad.MetaVars

-- | Various classes of metavariables.
data MetaClass

-- | Meta variables of record type.
Records :: MetaClass

-- | Meta variables of "hereditarily singleton" record type.
SingletonRecords :: MetaClass

-- | Meta variables of level type, if type-in-type is activated.
Levels :: MetaClass

-- | All possible metavariable classes.
allMetaClasses :: [MetaClass]
data KeepMetas
KeepMetas :: KeepMetas
RollBackMetas :: KeepMetas

-- | Monad service class for creating, solving and eta-expanding of
--   metavariables.
class (MonadConstraint m, MonadReduce m, MonadAddContext m, MonadTCEnv m, ReadTCState m, HasBuiltins m, HasConstInfo m, MonadDebug m) => MonadMetaSolver m

-- | Generate a new meta variable with some instantiation given. For
--   instance, the instantiation could be a
--   <a>PostponedTypeCheckingProblem</a>.
newMeta' :: MonadMetaSolver m => MetaInstantiation -> Frozen -> MetaInfo -> MetaPriority -> Permutation -> Judgement a -> m MetaId

-- | Assign to an open metavar which may not be frozen. First check that
--   metavar args are in pattern fragment. Then do extended occurs check on
--   given thing.
--   
--   Assignment is aborted by throwing a <tt>PatternErr</tt> via a call to
--   <tt>patternViolation</tt>. This error is caught by
--   <tt>catchConstraint</tt> during equality checking
--   (<tt>compareAtom</tt>) and leads to restoration of the original
--   constraints.
assignV :: MonadMetaSolver m => CompareDirection -> MetaId -> Args -> Term -> CompareAs -> m ()

-- | Directly instantiate the metavariable. Skip pattern check, occurs
--   check and frozen check. Used for eta expanding frozen metas.
assignTerm' :: (MonadMetaSolver m, MonadMetaSolver m) => MetaId -> [Arg ArgName] -> Term -> m ()

-- | Eta-expand a local meta-variable, if it is of the specified class.
--   Don't do anything if the meta-variable is a blocked term.
etaExpandMeta :: MonadMetaSolver m => [MetaClass] -> MetaId -> m ()

-- | Update the status of the metavariable
updateMetaVar :: MonadMetaSolver m => MetaId -> (MetaVariable -> MetaVariable) -> m ()

-- | 'speculateMetas fallback m' speculatively runs <tt>m</tt>, but if the
--   result is <a>RollBackMetas</a> any changes to metavariables are rolled
--   back and <tt>fallback</tt> is run instead.
speculateMetas :: MonadMetaSolver m => m () -> m KeepMetas -> m ()

-- | Switch off assignment of metas.
dontAssignMetas :: (MonadTCEnv m, HasOptions m, MonadDebug m) => m a -> m a

-- | Is the meta-variable from another top-level module?
isRemoteMeta :: ReadTCState m => m (MetaId -> Bool)

-- | If another meta-variable is created, then it will get this
--   <a>MetaId</a> (unless the state is changed too much, for instance by
--   <a>setTopLevelModule</a>).
nextLocalMeta :: ReadTCState m => m MetaId

-- | Pairs of local meta-stores.
data LocalMetaStores
LocalMetaStores :: LocalMetaStore -> LocalMetaStore -> LocalMetaStores

-- | A <tt>MetaStore</tt> containing open meta-variables.
[openMetas] :: LocalMetaStores -> LocalMetaStore

-- | A <tt>MetaStore</tt> containing instantiated meta-variables.
[solvedMetas] :: LocalMetaStores -> LocalMetaStore

-- | Run a computation and record which new metas it created.
metasCreatedBy :: forall m a. ReadTCState m => m a -> m (a, LocalMetaStores)

-- | Find information about the given local meta-variable, if any.
lookupLocalMeta' :: ReadTCState m => MetaId -> m (Maybe MetaVariable)

-- | Find information about the given local meta-variable.
lookupLocalMeta :: (HasCallStack, MonadDebug m, ReadTCState m) => MetaId -> m MetaVariable

-- | Find information about the (local or remote) meta-variable, if any.
--   
--   If no meta-variable is found, then the reason could be that the
--   dead-code elimination (<a>eliminateDeadCode</a>) failed to find the
--   meta-variable, perhaps because some <tt>NamesIn</tt> instance is
--   incorrectly defined.
lookupMeta :: ReadTCState m => MetaId -> m (Maybe (Either RemoteMetaVariable MetaVariable))

-- | Find the meta-variable's instantiation.
lookupMetaInstantiation :: ReadTCState m => MetaId -> m MetaInstantiation

-- | Find the meta-variable's judgement.
lookupMetaJudgement :: ReadTCState m => MetaId -> m (Judgement MetaId)

-- | Find the meta-variable's modality.
lookupMetaModality :: ReadTCState m => MetaId -> m Modality

-- | The type of a term or sort meta-variable.
metaType :: ReadTCState m => MetaId -> m Type

-- | Update the information associated with a local meta-variable.
updateMetaVarTCM :: HasCallStack => MetaId -> (MetaVariable -> MetaVariable) -> TCM ()

-- | Insert a new meta-variable with associated information into the local
--   meta store.
insertMetaVar :: MetaId -> MetaVariable -> TCM ()

-- | Returns the <a>MetaPriority</a> of the given local meta-variable.
getMetaPriority :: (HasCallStack, MonadDebug m, ReadTCState m) => MetaId -> m MetaPriority
isSortMeta :: ReadTCState m => MetaId -> m Bool
isSortMeta_ :: MetaVariable -> Bool
isSortJudgement :: Judgement a -> Bool

-- | If a meta variable is still open, what is its kind?
metaInstantiationToMetaKind :: MetaInstantiation -> MetaKind
getMetaType :: ReadTCState m => MetaId -> m Type

-- | Compute the context variables that a local meta-variable should be
--   applied to, accounting for pruning.
getMetaContextArgs :: MonadTCEnv m => MetaVariable -> m Args

-- | Given a local meta-variable, return the type applied to the current
--   context.
getMetaTypeInContext :: (HasBuiltins m, HasCallStack, MonadDebug m, MonadReduce m, MonadTCEnv m, ReadTCState m) => MetaId -> m Type

-- | Is it a local meta-variable that might be generalized?
isGeneralizableMeta :: (HasCallStack, MonadDebug m, ReadTCState m) => MetaId -> m DoGeneralize

-- | Check whether all metas are instantiated. Precondition: argument is a
--   meta (in some form) or a list of metas.
class IsInstantiatedMeta a
isInstantiatedMeta :: (IsInstantiatedMeta a, MonadFail m, ReadTCState m) => a -> m Bool
isInstantiatedMeta' :: (MonadFail m, ReadTCState m) => MetaId -> m (Maybe Term)

-- | Returns all metavariables in a constraint. Slightly complicated by the
--   fact that blocked terms are represented by two meta variables. To find
--   the second one we need to look up the meta listeners for the one in
--   the UnBlock constraint. This is used for the purpose of deciding if a
--   metavariable is constrained or if it can be generalized over (see
--   Agda.TypeChecking.Generalize).
constraintMetas :: Constraint -> TCM (Set MetaId)

-- | Create <a>MetaInfo</a> in the current environment.
createMetaInfo :: (MonadTCEnv m, ReadTCState m) => m MetaInfo
createMetaInfo' :: (MonadTCEnv m, ReadTCState m) => RunMetaOccursCheck -> m MetaInfo
setValueMetaName :: MonadMetaSolver m => Term -> MetaNameSuggestion -> m ()
getMetaNameSuggestion :: (HasCallStack, MonadDebug m, ReadTCState m) => MetaId -> m MetaNameSuggestion
setMetaNameSuggestion :: MonadMetaSolver m => MetaId -> MetaNameSuggestion -> m ()

-- | Change the ArgInfo that will be used when generalizing over this local
--   meta-variable.
setMetaGeneralizableArgInfo :: MonadMetaSolver m => MetaId -> ArgInfo -> m ()
updateMetaVarRange :: MonadMetaSolver m => MetaId -> Range -> m ()
setMetaOccursCheck :: MonadMetaSolver m => MetaId -> RunMetaOccursCheck -> m ()
class (MonadTCEnv m, ReadTCState m) => MonadInteractionPoints m
freshInteractionId :: MonadInteractionPoints m => m InteractionId
freshInteractionId :: (MonadInteractionPoints m, MonadTrans t, MonadInteractionPoints n, t n ~ m) => m InteractionId
modifyInteractionPoints :: MonadInteractionPoints m => (InteractionPoints -> InteractionPoints) -> m ()
modifyInteractionPoints :: (MonadInteractionPoints m, MonadTrans t, MonadInteractionPoints n, t n ~ m) => (InteractionPoints -> InteractionPoints) -> m ()

-- | Register an interaction point during scope checking. If there is no
--   interaction id yet, create one.
registerInteractionPoint :: forall m. MonadInteractionPoints m => Bool -> Range -> Maybe Nat -> m InteractionId

-- | Find an interaction point by <a>Range'</a> by searching the whole map.
--   Issue 3000: Don't consider solved interaction points.
--   
--   O(n): linear in the number of registered interaction points.
findInteractionPoint_ :: Range -> InteractionPoints -> Maybe InteractionId

-- | Hook up a local meta-variable to an interaction point.
connectInteractionPoint :: MonadInteractionPoints m => InteractionId -> MetaId -> m ()

-- | Mark an interaction point as solved.
removeInteractionPoint :: MonadInteractionPoints m => InteractionId -> m ()

-- | Get a list of interaction ids.
getInteractionPoints :: ReadTCState m => m [InteractionId]

-- | Get all metas that correspond to unsolved interaction ids.
getInteractionMetas :: ReadTCState m => m [MetaId]
getUniqueMetasRanges :: (HasCallStack, MonadDebug m, ReadTCState m) => [MetaId] -> m [Range]
getUnsolvedMetas :: (HasCallStack, MonadDebug m, ReadTCState m) => m [Range]
getUnsolvedInteractionMetas :: (HasCallStack, MonadDebug m, ReadTCState m) => m [Range]

-- | Get all metas that correspond to unsolved interaction ids.
getInteractionIdsAndMetas :: ReadTCState m => m [(InteractionId, MetaId)]

-- | Does the meta variable correspond to an interaction point?
--   
--   Time: <tt>O(log n)</tt> where <tt>n</tt> is the number of interaction
--   metas.
isInteractionMeta :: ReadTCState m => MetaId -> m (Maybe InteractionId)

-- | Get the information associated to an interaction point.
lookupInteractionPoint :: (MonadFail m, ReadTCState m, MonadError TCErr m) => InteractionId -> m InteractionPoint

-- | Get <a>MetaId</a> for an interaction point. Precondition: interaction
--   point is connected.
lookupInteractionId :: (MonadFail m, ReadTCState m, MonadError TCErr m, MonadTCEnv m) => InteractionId -> m MetaId

-- | Check whether an interaction id is already associated with a meta
--   variable.
lookupInteractionMeta :: ReadTCState m => InteractionId -> m (Maybe MetaId)
lookupInteractionMeta_ :: InteractionId -> InteractionPoints -> Maybe MetaId

-- | Generate new meta variable.
newMeta :: MonadMetaSolver m => Frozen -> MetaInfo -> MetaPriority -> Permutation -> Judgement a -> m MetaId

-- | Generate a new meta variable with some instantiation given. For
--   instance, the instantiation could be a
--   <a>PostponedTypeCheckingProblem</a>.
newMetaTCM' :: MetaInstantiation -> Frozen -> MetaInfo -> MetaPriority -> Permutation -> Judgement a -> TCM MetaId

-- | Get the <a>Range'</a> for an interaction point.
getInteractionRange :: (MonadInteractionPoints m, MonadFail m, MonadError TCErr m) => InteractionId -> m Range

-- | Get the <a>Range'</a> for a local meta-variable.
getMetaRange :: (HasCallStack, MonadDebug m, ReadTCState m) => MetaId -> m Range
getInteractionScope :: (MonadDebug m, MonadFail m, ReadTCState m, MonadError TCErr m, MonadTCEnv m) => InteractionId -> m ScopeInfo
withMetaInfo' :: (MonadTCEnv m, ReadTCState m, MonadTrace m) => MetaVariable -> m a -> m a
withMetaInfo :: (MonadTCEnv m, ReadTCState m, MonadTrace m) => Closure Range -> m a -> m a
withInteractionId :: (MonadDebug m, MonadFail m, ReadTCState m, MonadError TCErr m, MonadTCEnv m, MonadTrace m) => InteractionId -> m a -> m a
withMetaId :: (HasCallStack, MonadDebug m, MonadTCEnv m, MonadTrace m, ReadTCState m) => MetaId -> m a -> m a
getOpenMetas :: ReadTCState m => m [MetaId]
isOpenMeta :: MetaInstantiation -> Bool

-- | <tt>listenToMeta l m</tt>: register <tt>l</tt> as a listener to
--   <tt>m</tt>. This is done when the type of l is blocked by <tt>m</tt>.
listenToMeta :: MonadMetaSolver m => Listener -> MetaId -> m ()

-- | Unregister a listener.
unlistenToMeta :: MonadMetaSolver m => Listener -> MetaId -> m ()

-- | Get the listeners for a local meta-variable.
getMetaListeners :: (HasCallStack, MonadDebug m, ReadTCState m) => MetaId -> m [Listener]
clearMetaListeners :: MonadMetaSolver m => MetaId -> m ()

-- | Do safe eta-expansions for meta (<tt>SingletonRecords,Levels</tt>).
etaExpandMetaSafe :: MonadMetaSolver m => MetaId -> m ()

-- | Eta expand metavariables listening on the current meta.
etaExpandListeners :: MonadMetaSolver m => MetaId -> m ()

-- | Wake up a meta listener and let it do its thing
wakeupListener :: MonadMetaSolver m => Listener -> m ()
solveAwakeConstraints :: MonadConstraint m => m ()
solveAwakeConstraints' :: MonadConstraint m => Bool -> m ()

-- | Freeze the given meta-variables (but only if they are open) and return
--   those that were not already frozen.
freezeMetas :: forall m. MonadTCState m => LocalMetaStore -> m (Set MetaId)

-- | Thaw all open meta variables.
unfreezeMetas :: TCM ()
isFrozen :: (HasCallStack, MonadDebug m, ReadTCState m) => MetaId -> m Bool
withFrozenMetas :: (MonadMetaSolver m, MonadTCState m) => m a -> m a

-- | Unfreeze a meta and its type if this is a meta again. Does not
--   unfreeze deep occurrences of meta-variables or remote meta-variables.
class UnFreezeMeta a
unfreezeMeta :: (UnFreezeMeta a, MonadMetaSolver m) => a -> m ()
instance GHC.Show.Show Agda.TypeChecking.Monad.MetaVars.MetaClass
instance GHC.Enum.Bounded Agda.TypeChecking.Monad.MetaVars.MetaClass
instance GHC.Enum.Enum Agda.TypeChecking.Monad.MetaVars.MetaClass
instance GHC.Classes.Eq Agda.TypeChecking.Monad.MetaVars.MetaClass
instance Agda.TypeChecking.Monad.MetaVars.UnFreezeMeta Agda.Syntax.Common.MetaId
instance Agda.TypeChecking.Monad.MetaVars.UnFreezeMeta Agda.Syntax.Internal.Type
instance Agda.TypeChecking.Monad.MetaVars.UnFreezeMeta Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Monad.MetaVars.UnFreezeMeta Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Monad.MetaVars.UnFreezeMeta Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Monad.MetaVars.UnFreezeMeta Agda.Syntax.Internal.PlusLevel
instance Agda.TypeChecking.Monad.MetaVars.UnFreezeMeta a => Agda.TypeChecking.Monad.MetaVars.UnFreezeMeta [a]
instance Agda.TypeChecking.Monad.MetaVars.UnFreezeMeta a => Agda.TypeChecking.Monad.MetaVars.UnFreezeMeta (Agda.Syntax.Internal.Abs a)
instance Agda.TypeChecking.Monad.MetaVars.MonadInteractionPoints m => Agda.TypeChecking.Monad.MetaVars.MonadInteractionPoints (Control.Monad.Trans.Identity.IdentityT m)
instance Agda.TypeChecking.Monad.MetaVars.MonadInteractionPoints m => Agda.TypeChecking.Monad.MetaVars.MonadInteractionPoints (Control.Monad.Trans.Reader.ReaderT r m)
instance Agda.TypeChecking.Monad.MetaVars.MonadInteractionPoints m => Agda.TypeChecking.Monad.MetaVars.MonadInteractionPoints (Control.Monad.Trans.State.Lazy.StateT s m)
instance Agda.TypeChecking.Monad.MetaVars.MonadInteractionPoints Agda.TypeChecking.Monad.Base.TCM
instance Agda.TypeChecking.Monad.MetaVars.IsInstantiatedMeta Agda.Syntax.Common.MetaId
instance Agda.TypeChecking.Monad.MetaVars.IsInstantiatedMeta Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Monad.MetaVars.IsInstantiatedMeta Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Monad.MetaVars.IsInstantiatedMeta Agda.Syntax.Internal.PlusLevel
instance Agda.TypeChecking.Monad.MetaVars.IsInstantiatedMeta a => Agda.TypeChecking.Monad.MetaVars.IsInstantiatedMeta [a]
instance Agda.TypeChecking.Monad.MetaVars.IsInstantiatedMeta a => Agda.TypeChecking.Monad.MetaVars.IsInstantiatedMeta (GHC.Maybe.Maybe a)
instance Agda.TypeChecking.Monad.MetaVars.IsInstantiatedMeta a => Agda.TypeChecking.Monad.MetaVars.IsInstantiatedMeta (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Monad.MetaVars.IsInstantiatedMeta a => Agda.TypeChecking.Monad.MetaVars.IsInstantiatedMeta (Agda.Syntax.Internal.Abs a)
instance Agda.TypeChecking.Monad.MetaVars.MonadMetaSolver m => Agda.TypeChecking.Monad.MetaVars.MonadMetaSolver (Control.Monad.Trans.Reader.ReaderT r m)


-- | The translation of abstract syntax to concrete syntax has two
--   purposes. First it allows us to pretty print abstract syntax values
--   without having to write a dedicated pretty printer, and second it
--   serves as a sanity check for the concrete to abstract translation:
--   translating from concrete to abstract and then back again should be
--   (more or less) the identity.
module Agda.Syntax.Translation.AbstractToConcrete
class ToConcrete a where {
    type ConOfAbs a;
}
toConcrete :: ToConcrete a => a -> AbsToCon (ConOfAbs a)
bindToConcrete :: ToConcrete a => a -> (ConOfAbs a -> AbsToCon b) -> AbsToCon b

-- | Translate something in a context of the given precedence.
toConcreteCtx :: ToConcrete a => Precedence -> a -> AbsToCon (ConOfAbs a)
abstractToConcrete_ :: (ToConcrete a, MonadAbsToCon m) => a -> m (ConOfAbs a)
abstractToConcreteScope :: (ToConcrete a, MonadAbsToCon m) => ScopeInfo -> a -> m (ConOfAbs a)
abstractToConcreteHiding :: (LensHiding i, ToConcrete a, MonadAbsToCon m) => i -> a -> m (ConOfAbs a)
runAbsToCon :: MonadAbsToCon m => AbsToCon c -> m c
data RangeAndPragma
RangeAndPragma :: Range -> Pragma -> RangeAndPragma
abstractToConcreteCtx :: (ToConcrete a, MonadAbsToCon m) => Precedence -> a -> m (ConOfAbs a)
withScope :: ScopeInfo -> AbsToCon a -> AbsToCon a
preserveInteractionIds :: AbsToCon a -> AbsToCon a

-- | The function <a>runAbsToCon</a> can target any monad that satisfies
--   the constraints of <a>MonadAbsToCon</a>.
type MonadAbsToCon m = (MonadFresh NameId m, MonadInteractionPoints m, MonadStConcreteNames m, HasOptions m, PureTCM m, IsString (m Doc), Null (m Doc), Semigroup (m Doc))
data AbsToCon a
data Env
noTakenNames :: AbsToCon a -> AbsToCon a
lookupQName :: AllowAmbiguousNames -> QName -> AbsToCon QName
instance Data.Traversable.Traversable Agda.Syntax.Translation.AbstractToConcrete.MaybeSection
instance Data.Foldable.Foldable Agda.Syntax.Translation.AbstractToConcrete.MaybeSection
instance GHC.Base.Functor Agda.Syntax.Translation.AbstractToConcrete.MaybeSection
instance GHC.Show.Show a => GHC.Show.Show (Agda.Syntax.Translation.AbstractToConcrete.MaybeSection a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Syntax.Translation.AbstractToConcrete.MaybeSection a)
instance Agda.Syntax.Position.HasRange a => Agda.Syntax.Position.HasRange (Agda.Syntax.Translation.AbstractToConcrete.MaybeSection a)
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Abstract.Expr
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Translation.AbstractToConcrete.FreshenName
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Translation.AbstractToConcrete.BindingPattern
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Syntax.Translation.AbstractToConcrete.SplitPattern Agda.Syntax.Abstract.Pattern)
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Syntax.Translation.AbstractToConcrete.SplitPattern (Agda.Syntax.Common.NamedArg Agda.Syntax.Abstract.Pattern))
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Abstract.Pattern
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Syntax.Translation.AbstractToConcrete.UserPattern Agda.Syntax.Abstract.Pattern)
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Syntax.Translation.AbstractToConcrete.UserPattern (Agda.Syntax.Common.NamedArg Agda.Syntax.Abstract.Pattern))
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Abstract.Declaration
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Translation.AbstractToConcrete.RangeAndPragma
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete ()
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete GHC.Types.Bool
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete GHC.Types.Char
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete [a]
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Utils.List1.List1 a)
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (GHC.Maybe.Maybe a)
instance (Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a1, Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a2) => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Data.Either.Either a1 a2)
instance (Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a1, Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a2) => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (a1, a2)
instance (Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a1, Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a2, Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a3) => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (a1, a2, a3)
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Syntax.Common.WithHiding a)
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Syntax.Common.Named name a)
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Syntax.Common.Ranged a)
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Syntax.Concrete.FieldAssignment' a)
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Syntax.Concrete.TacticAttribute' a)
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Abstract.Name.Name
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Abstract.BindName
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Abstract.Name.QName
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Abstract.Name.ModuleName
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Scope.Base.AbstractName
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Scope.Base.ResolvedName
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Syntax.Abstract.Binder' a)
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Abstract.LamBinding
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Abstract.TypedBinding
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Abstract.LetBinding
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Abstract.WhereDeclarations
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Abstract.RHS
instance (Agda.Syntax.Translation.AbstractToConcrete.ToConcrete p, Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a) => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Syntax.Common.RewriteEqn' qn Agda.Syntax.Abstract.BindName p a)
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Syntax.Common.Constr Agda.Syntax.Abstract.Constructor)
instance (Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a, Agda.Syntax.Translation.AbstractToConcrete.ConOfAbs a GHC.Types.~ Agda.Syntax.Concrete.LHS) => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Syntax.Abstract.Clause' a)
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Abstract.ModuleApplication
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Abstract.RecordDirectives
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Abstract.SpineLHS
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Abstract.LHS
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Abstract.LHSCore
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.Syntax.Common.InteractionId
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete Agda.TypeChecking.Monad.Base.NamedMeta
instance GHC.Base.Functor Agda.Syntax.Translation.AbstractToConcrete.AbsToCon
instance GHC.Base.Applicative Agda.Syntax.Translation.AbstractToConcrete.AbsToCon
instance GHC.Base.Monad Agda.Syntax.Translation.AbstractToConcrete.AbsToCon
instance Control.Monad.Fail.MonadFail Agda.Syntax.Translation.AbstractToConcrete.AbsToCon
instance Control.Monad.Reader.Class.MonadReader Agda.Syntax.Translation.AbstractToConcrete.Env Agda.Syntax.Translation.AbstractToConcrete.AbsToCon
instance Agda.TypeChecking.Monad.Base.MonadTCEnv Agda.Syntax.Translation.AbstractToConcrete.AbsToCon
instance Agda.TypeChecking.Monad.Base.ReadTCState Agda.Syntax.Translation.AbstractToConcrete.AbsToCon
instance Agda.TypeChecking.Monad.Base.MonadStConcreteNames Agda.Syntax.Translation.AbstractToConcrete.AbsToCon
instance Agda.TypeChecking.Monad.Builtin.HasBuiltins Agda.Syntax.Translation.AbstractToConcrete.AbsToCon
instance Agda.Interaction.Options.HasOptions.HasOptions Agda.Syntax.Translation.AbstractToConcrete.AbsToCon
instance Agda.TypeChecking.Monad.Debug.MonadDebug Agda.Syntax.Translation.AbstractToConcrete.AbsToCon
instance Agda.TypeChecking.Monad.Signature.HasConstInfo Agda.Syntax.Translation.AbstractToConcrete.AbsToCon
instance Agda.TypeChecking.Monad.Context.MonadAddContext Agda.Syntax.Translation.AbstractToConcrete.AbsToCon
instance Agda.TypeChecking.Monad.Base.MonadReduce Agda.Syntax.Translation.AbstractToConcrete.AbsToCon
instance Agda.TypeChecking.Monad.Pure.PureTCM Agda.Syntax.Translation.AbstractToConcrete.AbsToCon
instance Agda.TypeChecking.Monad.Base.MonadFresh Agda.Syntax.Common.NameId Agda.Syntax.Translation.AbstractToConcrete.AbsToCon
instance Agda.TypeChecking.Monad.MetaVars.MonadInteractionPoints Agda.Syntax.Translation.AbstractToConcrete.AbsToCon
instance Data.String.IsString (Agda.Syntax.Translation.AbstractToConcrete.AbsToCon Agda.Syntax.Common.Pretty.Doc)
instance Agda.Utils.Null.Null (Agda.Syntax.Translation.AbstractToConcrete.AbsToCon Agda.Syntax.Common.Pretty.Doc)
instance GHC.Base.Semigroup (Agda.Syntax.Translation.AbstractToConcrete.AbsToCon Agda.Syntax.Common.Pretty.Doc)

module Agda.Syntax.Abstract.Pretty
showA :: (ToConcrete a, Show (ConOfAbs a), MonadAbsToCon m) => a -> m String
prettyA :: (ToConcrete a, Pretty (ConOfAbs a), MonadAbsToCon m) => a -> m Doc
prettyAs :: (ToConcrete a, ConOfAbs a ~ [ce], Pretty ce, MonadAbsToCon m) => a -> m Doc

-- | Variant of <a>showA</a> which does not insert outermost parentheses.
showATop :: (ToConcrete a, Show (ConOfAbs a), MonadAbsToCon m) => a -> m String

-- | Variant of <a>prettyA</a> which does not insert outermost parentheses.
prettyATop :: (ToConcrete a, Pretty (ConOfAbs a), MonadAbsToCon m) => a -> m Doc

module Agda.TypeChecking.Monad

module Agda.TypeChecking.Serialise.Instances.Compilers
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.CompilerPragma
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.ForeignCode
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.ForeignCodeStack

module Agda.TypeChecking.Serialise.Instances.Internal
blockedToMaybe :: Blocked_ -> Maybe NotBlocked
blockedFromMaybe :: Maybe NotBlocked -> Blocked_
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Internal.Dom a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.Signature
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.InstanceTable
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.Section
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Internal.Tele a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Utils.Permutation.Permutation
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Utils.Permutation.Drop a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Internal.DataOrRecord
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Internal.ConHead
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Internal.Type' a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Internal.Abs a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Internal.PlusLevel
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Internal.Univ.IsFibrant
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Internal.Univ.Univ
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.DisplayForm
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.TypeChecking.Monad.Base.Open a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.CheckpointId
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.DisplayTerm
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.MutualId
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.CompKit
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.InstanceInfo
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.Definition
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Internal.NotBlocked
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Internal.Blocked_
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.NLPat
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.NLPType
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.NLPSort
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.RewriteRule
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.Projection
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.ProjLams
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.System
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.ExtLamInfo
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.Polarity
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.IsForced
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.NumGeneralizableArgs
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.DoGeneralize
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Positivity.Occurrence.Occurrence
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.EtaEquality
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.ProjectionLikenessMissing
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.BuiltinSort
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.Defn
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Coverage.SplitTree.LazySplit
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Coverage.SplitTree.SplitTag
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.TypeChecking.Coverage.SplitTree.SplitTree' a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.FunctionFlag
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.TypeChecking.CompiledClause.WithArity a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.TypeChecking.CompiledClause.Case a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.OpaqueBlock
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.CompiledClause.CompiledClauses
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.TypeChecking.Monad.Base.FunctionInverse' a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.TermHead
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Internal.Clause
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Internal.ConPatternInfo
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Internal.DBPatVar
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Internal.PatternInfo
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Internal.PatOrigin
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Internal.Pattern' a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.TypeChecking.Monad.Base.Builtin a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.Syntax.Internal.Substitution' a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.Instantiation
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.Comparison
instance Agda.TypeChecking.Serialise.Base.EmbPrj a => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.TypeChecking.Monad.Base.Judgement a)
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.RemoteMetaVariable
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.DiscrimTree.Types.Key
instance (Agda.TypeChecking.Serialise.Base.EmbPrj a, GHC.Classes.Ord a) => Agda.TypeChecking.Serialise.Base.EmbPrj (Agda.TypeChecking.DiscrimTree.Types.DiscrimTree a)

module Agda.TypeChecking.Serialise.Instances.Errors
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.TCWarning
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.Warning
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.IllegalRewriteRuleReason
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Interaction.Options.Base.OptionWarning
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Interaction.Options.Warnings.WarningModeError
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Parser.Monad.ParseWarning
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.Warning.RecordFieldWarning
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Concrete.Definitions.Errors.DeclarationWarning
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Concrete.Definitions.Errors.DeclarationWarning'
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Interaction.Library.Base.LibWarning
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Interaction.Library.Base.LibWarning'
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Interaction.Library.Base.ExecutablesFile
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Interaction.Library.Base.LibPositionInfo
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Common.Pretty.Doc
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Interaction.Options.Base.InfectiveCoinfective
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Interaction.Options.Base.PragmaOptions
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Utils.ProfileOptions.ProfileOptions
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Utils.ProfileOptions.ProfileOption
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.LHSOrPatSyn
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Syntax.Concrete.Glyph.UnicodeOrAscii
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Interaction.Options.Base.ConfluenceCheck
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Interaction.Options.Warnings.WarningMode
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Interaction.Options.Warnings.WarningName
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.Termination.CutOff.CutOff

module Agda.TypeChecking.Serialise.Instances
instance Agda.TypeChecking.Serialise.Base.EmbPrj Agda.TypeChecking.Monad.Base.Interface


-- | Structure-sharing serialisation of Agda interface files.
module Agda.TypeChecking.Serialise

-- | Encodes something. To ensure relocatability file paths in positions
--   are replaced with module names.
encode :: EmbPrj a => a -> TCM Encoded

-- | Encodes an interface. To ensure relocatability file paths in positions
--   are replaced with module names.
--   
--   An uncompressed bytestring corresponding to the encoded interface is
--   returned.
encodeFile :: FilePath -> Interface -> TCM ByteString
encodeInterface :: Interface -> TCM Encoded

-- | Decodes an uncompressed bytestring (without extra hashes or magic
--   numbers). The result depends on the include path.
--   
--   Returns <a>Nothing</a> if a decoding error is encountered.
decode :: EmbPrj a => ByteString -> TCM (Maybe a)
decodeFile :: FilePath -> TCM (Maybe Interface)

-- | Decodes an interface. The result depends on the include path.
--   
--   Returns <a>Nothing</a> if the file does not start with the right magic
--   number or some other decoding error is encountered.
decodeInterface :: ByteString -> TCM (Maybe Interface)
decodeHashes :: ByteString -> Maybe (Hash, Hash)
class Typeable a => EmbPrj a
instance Data.Binary.Class.Binary a => Data.Binary.Class.Binary (Agda.TypeChecking.Serialise.ListLike a)

module Agda.TypeChecking.Rewriting.Clause

-- | Get all the clauses of a definition and convert them to rewrite rules.
getClausesAsRewriteRules :: (HasConstInfo m, MonadFresh NameId m) => QName -> m [RewriteRule]

-- | Generate a sensible name for the given clause
clauseQName :: (HasConstInfo m, MonadFresh NameId m) => QName -> Int -> m QName

-- | <tt>clauseToRewriteRule f q cl</tt> converts the clause <tt>cl</tt> of
--   the function <tt>f</tt> to a rewrite rule with name <tt>q</tt>.
--   Returns <tt>Nothing</tt> if <tt>clauseBody cl</tt> is
--   <tt>Nothing</tt>. Precondition: <tt>clauseType cl</tt> is not
--   <tt>Nothing</tt>.
clauseToRewriteRule :: QName -> QName -> Clause -> Maybe RewriteRule
class ToNLPat a b
toNLPat :: ToNLPat a b => a -> b
toNLPat :: (ToNLPat a b, ToNLPat a' b', Functor f, a ~ f a', b ~ f b') => a -> b
instance Agda.TypeChecking.Rewriting.Clause.ToNLPat a b => Agda.TypeChecking.Rewriting.Clause.ToNLPat [a] [b]
instance Agda.TypeChecking.Rewriting.Clause.ToNLPat a b => Agda.TypeChecking.Rewriting.Clause.ToNLPat (Agda.Syntax.Internal.Dom a) (Agda.Syntax.Internal.Dom b)
instance Agda.TypeChecking.Rewriting.Clause.ToNLPat a b => Agda.TypeChecking.Rewriting.Clause.ToNLPat (Agda.Syntax.Internal.Elim.Elim' a) (Agda.Syntax.Internal.Elim.Elim' b)
instance Agda.TypeChecking.Rewriting.Clause.ToNLPat a b => Agda.TypeChecking.Rewriting.Clause.ToNLPat (Agda.Syntax.Internal.Abs a) (Agda.Syntax.Internal.Abs b)
instance Agda.TypeChecking.Rewriting.Clause.ToNLPat (Agda.Syntax.Common.Arg Agda.Syntax.Internal.DeBruijnPattern) (Agda.Syntax.Internal.Elim.Elim' Agda.TypeChecking.Monad.Base.NLPat)
instance Agda.TypeChecking.Rewriting.Clause.ToNLPat (Agda.Syntax.Common.NamedArg Agda.Syntax.Internal.DeBruijnPattern) (Agda.Syntax.Internal.Elim.Elim' Agda.TypeChecking.Monad.Base.NLPat)

module Agda.TypeChecking.Reduce.Monad
constructorForm :: HasBuiltins m => Term -> m Term
enterClosure :: LensClosure c a => c -> (a -> ReduceM b) -> ReduceM b

-- | Lookup the definition of a name. The result is a closed thing, all
--   free variables have been abstracted over.
getConstInfo :: HasConstInfo m => QName -> m Definition
askR :: ReduceM ReduceEnv

-- | Apply a function if a certain verbosity level is activated.
--   
--   Precondition: The level must be non-negative.
applyWhenVerboseS :: MonadDebug m => VerboseKey -> VerboseLevel -> (m a -> m a) -> m a -> m a
instance Agda.TypeChecking.Monad.Builtin.HasBuiltins Agda.TypeChecking.Monad.Base.ReduceM
instance Agda.TypeChecking.Monad.Context.MonadAddContext Agda.TypeChecking.Monad.Base.ReduceM
instance Agda.TypeChecking.Monad.Debug.MonadDebug Agda.TypeChecking.Monad.Base.ReduceM
instance Agda.TypeChecking.Monad.Signature.HasConstInfo Agda.TypeChecking.Monad.Base.ReduceM
instance Agda.TypeChecking.Monad.Pure.PureTCM Agda.TypeChecking.Monad.Base.ReduceM


-- | Facility to test throwing internal errors.
module Agda.ImpossibleTest

-- | If the given list of words is non-empty, print them as debug message
--   (using <a>__IMPOSSIBLE_VERBOSE__</a>) before raising the internal
--   error.
impossibleTest :: (MonadDebug m, HasCallStack) => [String] -> m a
impossibleTestReduceM :: HasCallStack => [String] -> TCM a

module Agda.TypeChecking.MetaVars.Mention
class MentionsMeta t
mentionsMetas :: MentionsMeta t => HashSet MetaId -> t -> Bool
mentionsMeta :: MentionsMeta t => MetaId -> t -> Bool
instance Agda.TypeChecking.MetaVars.Mention.MentionsMeta Agda.Syntax.Internal.Term
instance Agda.TypeChecking.MetaVars.Mention.MentionsMeta Agda.Syntax.Internal.Level
instance Agda.TypeChecking.MetaVars.Mention.MentionsMeta Agda.Syntax.Internal.PlusLevel
instance Agda.TypeChecking.MetaVars.Mention.MentionsMeta Agda.Syntax.Internal.Blockers.Blocker
instance Agda.TypeChecking.MetaVars.Mention.MentionsMeta Agda.Syntax.Internal.Type
instance Agda.TypeChecking.MetaVars.Mention.MentionsMeta Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.MetaVars.Mention.MentionsMeta t => Agda.TypeChecking.MetaVars.Mention.MentionsMeta (Agda.Syntax.Internal.Abs t)
instance Agda.TypeChecking.MetaVars.Mention.MentionsMeta t => Agda.TypeChecking.MetaVars.Mention.MentionsMeta (Agda.Syntax.Common.Arg t)
instance Agda.TypeChecking.MetaVars.Mention.MentionsMeta t => Agda.TypeChecking.MetaVars.Mention.MentionsMeta (Agda.Syntax.Internal.Dom t)
instance Agda.TypeChecking.MetaVars.Mention.MentionsMeta t => Agda.TypeChecking.MetaVars.Mention.MentionsMeta [t]
instance Agda.TypeChecking.MetaVars.Mention.MentionsMeta t => Agda.TypeChecking.MetaVars.Mention.MentionsMeta (GHC.Maybe.Maybe t)
instance (Agda.TypeChecking.MetaVars.Mention.MentionsMeta a, Agda.TypeChecking.MetaVars.Mention.MentionsMeta b) => Agda.TypeChecking.MetaVars.Mention.MentionsMeta (a, b)
instance (Agda.TypeChecking.MetaVars.Mention.MentionsMeta a, Agda.TypeChecking.MetaVars.Mention.MentionsMeta b, Agda.TypeChecking.MetaVars.Mention.MentionsMeta c) => Agda.TypeChecking.MetaVars.Mention.MentionsMeta (a, b, c)
instance Agda.TypeChecking.MetaVars.Mention.MentionsMeta a => Agda.TypeChecking.MetaVars.Mention.MentionsMeta (Agda.TypeChecking.Monad.Base.Closure a)
instance Agda.TypeChecking.MetaVars.Mention.MentionsMeta Agda.Syntax.Internal.Elim
instance Agda.TypeChecking.MetaVars.Mention.MentionsMeta a => Agda.TypeChecking.MetaVars.Mention.MentionsMeta (Agda.Syntax.Internal.Tele a)
instance Agda.TypeChecking.MetaVars.Mention.MentionsMeta Agda.TypeChecking.Monad.Base.ProblemConstraint
instance Agda.TypeChecking.MetaVars.Mention.MentionsMeta Agda.TypeChecking.Monad.Base.Constraint
instance Agda.TypeChecking.MetaVars.Mention.MentionsMeta Agda.TypeChecking.Monad.Base.CompareAs


-- | Compute eta short normal forms.
module Agda.TypeChecking.EtaContract
data BinAppView
App :: Term -> Arg Term -> BinAppView
NoApp :: Term -> BinAppView
binAppView :: Term -> BinAppView

-- | Contracts all eta-redexes it sees without reducing.
etaContract :: (MonadTCEnv m, HasConstInfo m, HasOptions m, TermLike a) => a -> m a
etaOnce :: (MonadTCEnv m, HasConstInfo m, HasOptions m) => Term -> m Term

-- | If record constructor, call eta-contraction function.
etaCon :: (MonadTCEnv m, HasConstInfo m, HasOptions m) => ConHead -> ConInfo -> Elims -> (QName -> ConHead -> ConInfo -> Args -> m Term) -> m Term

-- | Try to contract a lambda-abstraction <tt>Lam i (Abs x b)</tt>.
etaLam :: (MonadTCEnv m, HasConstInfo m, HasOptions m) => ArgInfo -> ArgName -> Term -> m Term

module Agda.TypeChecking.Reduce

-- | Instantiate something. Results in an open meta variable or a non meta.
--   Doesn't do any reduction, and preserves blocking tags (when blocking
--   meta is uninstantiated).
class Instantiate t
instantiate' :: Instantiate t => t -> ReduceM t
instantiate :: (Instantiate a, MonadReduce m) => a -> m a

-- | A variant of <a>instantiateFull</a> that only instantiates those
--   meta-variables that satisfy the predicate.
instantiateWhen :: (InstantiateFull a, MonadReduce m) => (MetaId -> ReduceM Bool) -> a -> m a

-- | <tt>instantiateFull'</tt> <a>instantiate</a>s metas everywhere (and
--   recursively) but does not <a>reduce</a>.
class InstantiateFull t
instantiateFull' :: InstantiateFull t => t -> ReduceM t
instantiateFull :: (InstantiateFull a, MonadReduce m) => a -> m a

-- | Is something (an elimination of) a meta variable? Does not perform any
--   reductions.
class IsMeta a
isMeta :: IsMeta a => a -> Maybe MetaId
class Reduce t
reduce' :: Reduce t => t -> ReduceM t
reduceB' :: Reduce t => t -> ReduceM (Blocked t)
reduce :: (Reduce a, MonadReduce m) => a -> m a
reduceB :: (Reduce a, MonadReduce m) => a -> m (Blocked a)
reduceWithBlocker :: (Reduce a, IsMeta a, MonadReduce m) => a -> m (Blocker, a)
reduceIApply' :: (Term -> ReduceM (Blocked Term)) -> ReduceM (Blocked Term) -> [Elim] -> ReduceM (Blocked Term)

-- | Reduce a non-primitive definition if it is a copy linking to another
--   def.
reduceDefCopy :: forall m. PureTCM m => QName -> Elims -> m (Reduced () Term)

-- | Specialized version to put in boot file.
reduceDefCopyTCM :: QName -> Elims -> TCM (Reduced () Term)

-- | Reduce simple (single clause) definitions.
reduceHead :: PureTCM m => Term -> m (Blocked Term)
slowReduceTerm :: Term -> ReduceM (Blocked Term)
unfoldCorecursion :: Term -> ReduceM (Blocked Term)
unfoldCorecursionE :: Elim -> ReduceM (Blocked Elim)
unfoldDefinitionE :: (Term -> ReduceM (Blocked Term)) -> Term -> QName -> Elims -> ReduceM (Blocked Term)
unfoldDefinitionStep :: Term -> QName -> Elims -> ReduceM (Reduced (Blocked Term) Term)

-- | Unfold a single inlined function.
unfoldInlined :: PureTCM m => Term -> m Term

-- | Apply a defined function to it's arguments, using the original
--   clauses.
appDef' :: QName -> Term -> [Clause] -> RewriteRules -> MaybeReducedArgs -> ReduceM (Reduced (Blocked Term) Term)
appDefE' :: QName -> Term -> [Clause] -> RewriteRules -> MaybeReducedElims -> ReduceM (Reduced (Blocked Term) Term)

-- | Throw pattern violation if blocked or a meta.
abortIfBlocked :: (MonadReduce m, MonadBlock m, IsMeta t, Reduce t) => t -> m t

-- | Case on whether a term is blocked on a meta (or is a meta). That means
--   it can change its shape when the meta is instantiated.
ifBlocked :: (Reduce t, IsMeta t, MonadReduce m) => t -> (Blocker -> t -> m a) -> (NotBlocked -> t -> m a) -> m a
isBlocked :: (Reduce t, IsMeta t, MonadReduce m) => t -> m (Maybe Blocker)

-- | Throw a pattern violation if the argument is <tt>Blocked</tt>,
--   otherwise return the value embedded in the <tt>NotBlocked</tt>.
fromBlocked :: MonadBlock m => Blocked a -> m a

-- | Run the given computation but turn any errors into blocked
--   computations with the given blocker
blockOnError :: MonadError TCErr m => Blocker -> m a -> m a

-- | Only unfold definitions if this leads to simplification which means
--   that a constructor/literal pattern is matched. We include reduction of
--   IApply patterns, as `p i0` is akin to matcing on the <tt>i0</tt>
--   constructor of interval.
class Simplify t
simplify :: (Simplify a, MonadReduce m) => a -> m a
simplifyBlocked' :: Simplify t => Blocked t -> ReduceM t
class Normalise t
normalise' :: Normalise t => t -> ReduceM t
normalise :: (Normalise a, MonadReduce m) => a -> m a
slowNormaliseArgs :: Term -> ReduceM Term
instance Agda.TypeChecking.Reduce.InstantiateFull t => Agda.TypeChecking.Reduce.InstantiateFull [t]
instance Agda.TypeChecking.Reduce.InstantiateFull t => Agda.TypeChecking.Reduce.InstantiateFull (Data.HashMap.Internal.HashMap k t)
instance Agda.TypeChecking.Reduce.InstantiateFull t => Agda.TypeChecking.Reduce.InstantiateFull (Data.Map.Internal.Map k t)
instance Agda.TypeChecking.Reduce.InstantiateFull t => Agda.TypeChecking.Reduce.InstantiateFull (GHC.Maybe.Maybe t)
instance Agda.TypeChecking.Reduce.InstantiateFull t => Agda.TypeChecking.Reduce.InstantiateFull (Data.Strict.Maybe.Maybe t)
instance Agda.TypeChecking.Reduce.InstantiateFull t => Agda.TypeChecking.Reduce.InstantiateFull (Agda.Syntax.Common.Arg t)
instance Agda.TypeChecking.Reduce.InstantiateFull t => Agda.TypeChecking.Reduce.InstantiateFull (Agda.Syntax.Internal.Elim.Elim' t)
instance Agda.TypeChecking.Reduce.InstantiateFull t => Agda.TypeChecking.Reduce.InstantiateFull (Agda.Syntax.Common.Named name t)
instance Agda.TypeChecking.Reduce.InstantiateFull t => Agda.TypeChecking.Reduce.InstantiateFull (Agda.TypeChecking.CompiledClause.WithArity t)
instance Agda.TypeChecking.Reduce.InstantiateFull t => Agda.TypeChecking.Reduce.InstantiateFull (Agda.TypeChecking.Monad.Base.IPBoundary' t)
instance (Agda.TypeChecking.Reduce.InstantiateFull a, Agda.TypeChecking.Reduce.InstantiateFull b) => Agda.TypeChecking.Reduce.InstantiateFull (a, b)
instance (Agda.TypeChecking.Reduce.InstantiateFull a, Agda.TypeChecking.Reduce.InstantiateFull b, Agda.TypeChecking.Reduce.InstantiateFull c) => Agda.TypeChecking.Reduce.InstantiateFull (a, b, c)
instance (Agda.TypeChecking.Reduce.InstantiateFull a, Agda.TypeChecking.Reduce.InstantiateFull b, Agda.TypeChecking.Reduce.InstantiateFull c, Agda.TypeChecking.Reduce.InstantiateFull d) => Agda.TypeChecking.Reduce.InstantiateFull (a, b, c, d)
instance Agda.TypeChecking.Reduce.InstantiateFull GHC.Types.Bool
instance Agda.TypeChecking.Reduce.InstantiateFull GHC.Types.Char
instance Agda.TypeChecking.Reduce.InstantiateFull GHC.Types.Int
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.Syntax.Abstract.Name.ModuleName
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.Syntax.Abstract.Name.Name
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.Syntax.Abstract.Name.QName
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.Syntax.Scope.Base.Scope
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.Syntax.Internal.ConHead
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.Syntax.Internal.DBPatVar
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.Syntax.Builtin.PrimitiveId
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Reduce.InstantiateFull t => Agda.TypeChecking.Reduce.InstantiateFull (Agda.Syntax.Internal.Type' t)
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.Syntax.Internal.PlusLevel
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.Syntax.Internal.Substitution
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.Syntax.Internal.ConPatternInfo
instance Agda.TypeChecking.Reduce.InstantiateFull a => Agda.TypeChecking.Reduce.InstantiateFull (Agda.Syntax.Internal.Pattern' a)
instance (Agda.TypeChecking.Substitute.Class.Subst a, Agda.TypeChecking.Reduce.InstantiateFull a) => Agda.TypeChecking.Reduce.InstantiateFull (Agda.Syntax.Internal.Abs a)
instance (Agda.TypeChecking.Reduce.InstantiateFull t, Agda.TypeChecking.Reduce.InstantiateFull e) => Agda.TypeChecking.Reduce.InstantiateFull (Agda.Syntax.Internal.Dom' t e)
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.LetBinding
instance Agda.TypeChecking.Reduce.InstantiateFull t => Agda.TypeChecking.Reduce.InstantiateFull (Agda.TypeChecking.Monad.Base.Open t)
instance Agda.TypeChecking.Reduce.InstantiateFull a => Agda.TypeChecking.Reduce.InstantiateFull (Agda.TypeChecking.Monad.Base.Closure a)
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.ProblemConstraint
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.Constraint
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.CompareAs
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.Signature
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.Section
instance (Agda.TypeChecking.Substitute.Class.Subst a, Agda.TypeChecking.Reduce.InstantiateFull a) => Agda.TypeChecking.Reduce.InstantiateFull (Agda.Syntax.Internal.Tele a)
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.Definition
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.NLPat
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.NLPType
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.NLPSort
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.RewriteRule
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.DisplayForm
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.DisplayTerm
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.Defn
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.ExtLamInfo
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.System
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.FunctionInverse
instance Agda.TypeChecking.Reduce.InstantiateFull a => Agda.TypeChecking.Reduce.InstantiateFull (Agda.TypeChecking.CompiledClause.Case a)
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.CompiledClause.CompiledClauses
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.Syntax.Internal.Clause
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.Instantiation
instance Agda.TypeChecking.Reduce.InstantiateFull (Agda.TypeChecking.Monad.Base.Judgement Agda.Syntax.Common.MetaId)
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.RemoteMetaVariable
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.Interface
instance Agda.TypeChecking.Reduce.InstantiateFull a => Agda.TypeChecking.Reduce.InstantiateFull (Agda.TypeChecking.Monad.Base.Builtin a)
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Monad.Base.Candidate
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.Syntax.Internal.EqualityView
instance Agda.TypeChecking.Reduce.Normalise t => Agda.TypeChecking.Reduce.Normalise [t]
instance Agda.TypeChecking.Reduce.Normalise t => Agda.TypeChecking.Reduce.Normalise (Data.Map.Internal.Map k t)
instance Agda.TypeChecking.Reduce.Normalise t => Agda.TypeChecking.Reduce.Normalise (GHC.Maybe.Maybe t)
instance Agda.TypeChecking.Reduce.Normalise t => Agda.TypeChecking.Reduce.Normalise (Data.Strict.Maybe.Maybe t)
instance Agda.TypeChecking.Reduce.Normalise t => Agda.TypeChecking.Reduce.Normalise (Agda.Syntax.Common.Named name t)
instance Agda.TypeChecking.Reduce.Normalise t => Agda.TypeChecking.Reduce.Normalise (Agda.TypeChecking.Monad.Base.IPBoundary' t)
instance Agda.TypeChecking.Reduce.Normalise t => Agda.TypeChecking.Reduce.Normalise (Agda.Syntax.Common.WithHiding t)
instance (Agda.TypeChecking.Reduce.Normalise a, Agda.TypeChecking.Reduce.Normalise b) => Agda.TypeChecking.Reduce.Normalise (a, b)
instance (Agda.TypeChecking.Reduce.Normalise a, Agda.TypeChecking.Reduce.Normalise b, Agda.TypeChecking.Reduce.Normalise c) => Agda.TypeChecking.Reduce.Normalise (a, b, c)
instance Agda.TypeChecking.Reduce.Normalise GHC.Types.Bool
instance Agda.TypeChecking.Reduce.Normalise GHC.Types.Char
instance Agda.TypeChecking.Reduce.Normalise GHC.Types.Int
instance Agda.TypeChecking.Reduce.Normalise Agda.Syntax.Internal.DBPatVar
instance Agda.TypeChecking.Reduce.Normalise Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Reduce.Normalise t => Agda.TypeChecking.Reduce.Normalise (Agda.Syntax.Internal.Type' t)
instance Agda.TypeChecking.Reduce.Normalise Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Reduce.Normalise t => Agda.TypeChecking.Reduce.Normalise (Agda.Syntax.Internal.Elim.Elim' t)
instance Agda.TypeChecking.Reduce.Normalise Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Reduce.Normalise Agda.Syntax.Internal.PlusLevel
instance (Agda.TypeChecking.Substitute.Class.Subst a, Agda.TypeChecking.Reduce.Normalise a) => Agda.TypeChecking.Reduce.Normalise (Agda.Syntax.Internal.Abs a)
instance Agda.TypeChecking.Reduce.Normalise t => Agda.TypeChecking.Reduce.Normalise (Agda.Syntax.Common.Arg t)
instance Agda.TypeChecking.Reduce.Normalise t => Agda.TypeChecking.Reduce.Normalise (Agda.Syntax.Internal.Dom t)
instance Agda.TypeChecking.Reduce.Normalise a => Agda.TypeChecking.Reduce.Normalise (Agda.TypeChecking.Monad.Base.Closure a)
instance (Agda.TypeChecking.Substitute.Class.Subst a, Agda.TypeChecking.Reduce.Normalise a) => Agda.TypeChecking.Reduce.Normalise (Agda.Syntax.Internal.Tele a)
instance Agda.TypeChecking.Reduce.Normalise Agda.TypeChecking.Monad.Base.ProblemConstraint
instance Agda.TypeChecking.Reduce.Normalise Agda.TypeChecking.Monad.Base.Constraint
instance Agda.TypeChecking.Reduce.Normalise Agda.TypeChecking.Monad.Base.CompareAs
instance Agda.TypeChecking.Reduce.Normalise Agda.Syntax.Internal.ConPatternInfo
instance Agda.TypeChecking.Reduce.Normalise a => Agda.TypeChecking.Reduce.Normalise (Agda.Syntax.Internal.Pattern' a)
instance Agda.TypeChecking.Reduce.Normalise Agda.TypeChecking.Monad.Base.DisplayForm
instance Agda.TypeChecking.Reduce.Normalise Agda.TypeChecking.Monad.Base.Candidate
instance Agda.TypeChecking.Reduce.Normalise Agda.Syntax.Internal.EqualityView
instance Agda.TypeChecking.Reduce.Simplify t => Agda.TypeChecking.Reduce.Simplify [t]
instance Agda.TypeChecking.Reduce.Simplify t => Agda.TypeChecking.Reduce.Simplify (Data.Map.Internal.Map k t)
instance Agda.TypeChecking.Reduce.Simplify t => Agda.TypeChecking.Reduce.Simplify (GHC.Maybe.Maybe t)
instance Agda.TypeChecking.Reduce.Simplify t => Agda.TypeChecking.Reduce.Simplify (Data.Strict.Maybe.Maybe t)
instance Agda.TypeChecking.Reduce.Simplify t => Agda.TypeChecking.Reduce.Simplify (Agda.Syntax.Common.Arg t)
instance Agda.TypeChecking.Reduce.Simplify t => Agda.TypeChecking.Reduce.Simplify (Agda.Syntax.Internal.Elim.Elim' t)
instance Agda.TypeChecking.Reduce.Simplify t => Agda.TypeChecking.Reduce.Simplify (Agda.Syntax.Common.Named name t)
instance Agda.TypeChecking.Reduce.Simplify t => Agda.TypeChecking.Reduce.Simplify (Agda.TypeChecking.Monad.Base.IPBoundary' t)
instance (Agda.TypeChecking.Reduce.Simplify a, Agda.TypeChecking.Reduce.Simplify b) => Agda.TypeChecking.Reduce.Simplify (a, b)
instance (Agda.TypeChecking.Reduce.Simplify a, Agda.TypeChecking.Reduce.Simplify b, Agda.TypeChecking.Reduce.Simplify c) => Agda.TypeChecking.Reduce.Simplify (a, b, c)
instance Agda.TypeChecking.Reduce.Simplify GHC.Types.Bool
instance Agda.TypeChecking.Reduce.Simplify Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Reduce.Simplify t => Agda.TypeChecking.Reduce.Simplify (Agda.Syntax.Internal.Type' t)
instance Agda.TypeChecking.Reduce.Simplify Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Reduce.Simplify Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Reduce.Simplify Agda.Syntax.Internal.PlusLevel
instance (Agda.TypeChecking.Substitute.Class.Subst a, Agda.TypeChecking.Reduce.Simplify a) => Agda.TypeChecking.Reduce.Simplify (Agda.Syntax.Internal.Abs a)
instance Agda.TypeChecking.Reduce.Simplify t => Agda.TypeChecking.Reduce.Simplify (Agda.Syntax.Internal.Dom t)
instance Agda.TypeChecking.Reduce.Simplify a => Agda.TypeChecking.Reduce.Simplify (Agda.TypeChecking.Monad.Base.Closure a)
instance (Agda.TypeChecking.Substitute.Class.Subst a, Agda.TypeChecking.Reduce.Simplify a) => Agda.TypeChecking.Reduce.Simplify (Agda.Syntax.Internal.Tele a)
instance Agda.TypeChecking.Reduce.Simplify Agda.TypeChecking.Monad.Base.ProblemConstraint
instance Agda.TypeChecking.Reduce.Simplify Agda.TypeChecking.Monad.Base.Constraint
instance Agda.TypeChecking.Reduce.Simplify Agda.TypeChecking.Monad.Base.CompareAs
instance Agda.TypeChecking.Reduce.Simplify Agda.TypeChecking.Monad.Base.DisplayForm
instance Agda.TypeChecking.Reduce.Simplify Agda.TypeChecking.Monad.Base.Candidate
instance Agda.TypeChecking.Reduce.Simplify Agda.Syntax.Internal.EqualityView
instance Agda.TypeChecking.Reduce.Reduce Agda.Syntax.Internal.Type
instance Agda.TypeChecking.Reduce.Reduce Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Reduce.Reduce Agda.Syntax.Internal.Elim
instance Agda.TypeChecking.Reduce.Reduce Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Reduce.Reduce Agda.Syntax.Internal.PlusLevel
instance (Agda.TypeChecking.Substitute.Class.Subst a, Agda.TypeChecking.Reduce.Reduce a) => Agda.TypeChecking.Reduce.Reduce (Agda.Syntax.Internal.Abs a)
instance Agda.TypeChecking.Reduce.Reduce t => Agda.TypeChecking.Reduce.Reduce [t]
instance Agda.TypeChecking.Reduce.Reduce t => Agda.TypeChecking.Reduce.Reduce (GHC.Maybe.Maybe t)
instance Agda.TypeChecking.Reduce.Reduce t => Agda.TypeChecking.Reduce.Reduce (Agda.Syntax.Common.Arg t)
instance Agda.TypeChecking.Reduce.Reduce t => Agda.TypeChecking.Reduce.Reduce (Agda.Syntax.Internal.Dom t)
instance (Agda.TypeChecking.Reduce.Reduce a, Agda.TypeChecking.Reduce.Reduce b) => Agda.TypeChecking.Reduce.Reduce (a, b)
instance (Agda.TypeChecking.Reduce.Reduce a, Agda.TypeChecking.Reduce.Reduce b, Agda.TypeChecking.Reduce.Reduce c) => Agda.TypeChecking.Reduce.Reduce (a, b, c)
instance Agda.TypeChecking.Reduce.Reduce Agda.Syntax.Internal.DeBruijnPattern
instance Agda.TypeChecking.Reduce.Reduce Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Reduce.Reduce a => Agda.TypeChecking.Reduce.Reduce (Agda.TypeChecking.Monad.Base.Closure a)
instance Agda.TypeChecking.Reduce.Reduce Agda.Syntax.Internal.Telescope
instance Agda.TypeChecking.Reduce.Reduce Agda.TypeChecking.Monad.Base.Constraint
instance Agda.TypeChecking.Reduce.Reduce Agda.TypeChecking.Monad.Base.CompareAs
instance Agda.TypeChecking.Reduce.Reduce e => Agda.TypeChecking.Reduce.Reduce (Data.Map.Internal.Map k e)
instance Agda.TypeChecking.Reduce.Reduce Agda.TypeChecking.Monad.Base.Candidate
instance Agda.TypeChecking.Reduce.Reduce Agda.Syntax.Internal.EqualityView
instance Agda.TypeChecking.Reduce.Reduce t => Agda.TypeChecking.Reduce.Reduce (Agda.TypeChecking.Monad.Base.IPBoundary' t)
instance Agda.TypeChecking.Reduce.IsMeta Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Reduce.IsMeta a => Agda.TypeChecking.Reduce.IsMeta (Agda.Syntax.Internal.Sort' a)
instance Agda.TypeChecking.Reduce.IsMeta a => Agda.TypeChecking.Reduce.IsMeta (Agda.Syntax.Internal.Type'' t a)
instance Agda.TypeChecking.Reduce.IsMeta a => Agda.TypeChecking.Reduce.IsMeta (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.TypeChecking.Reduce.IsMeta a => Agda.TypeChecking.Reduce.IsMeta (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Reduce.IsMeta a => Agda.TypeChecking.Reduce.IsMeta (Agda.Syntax.Internal.Level' a)
instance Agda.TypeChecking.Reduce.IsMeta a => Agda.TypeChecking.Reduce.IsMeta (Agda.Syntax.Internal.PlusLevel' a)
instance Agda.TypeChecking.Reduce.IsMeta Agda.TypeChecking.Monad.Base.CompareAs
instance Agda.TypeChecking.Reduce.Instantiate t => Agda.TypeChecking.Reduce.Instantiate [t]
instance Agda.TypeChecking.Reduce.Instantiate t => Agda.TypeChecking.Reduce.Instantiate (Data.Map.Internal.Map k t)
instance Agda.TypeChecking.Reduce.Instantiate t => Agda.TypeChecking.Reduce.Instantiate (GHC.Maybe.Maybe t)
instance Agda.TypeChecking.Reduce.Instantiate t => Agda.TypeChecking.Reduce.Instantiate (Data.Strict.Maybe.Maybe t)
instance Agda.TypeChecking.Reduce.Instantiate t => Agda.TypeChecking.Reduce.Instantiate (Agda.Syntax.Internal.Abs t)
instance Agda.TypeChecking.Reduce.Instantiate t => Agda.TypeChecking.Reduce.Instantiate (Agda.Syntax.Common.Arg t)
instance Agda.TypeChecking.Reduce.Instantiate t => Agda.TypeChecking.Reduce.Instantiate (Agda.Syntax.Internal.Elim.Elim' t)
instance Agda.TypeChecking.Reduce.Instantiate t => Agda.TypeChecking.Reduce.Instantiate (Agda.Syntax.Internal.Tele t)
instance Agda.TypeChecking.Reduce.Instantiate t => Agda.TypeChecking.Reduce.Instantiate (Agda.TypeChecking.Monad.Base.IPBoundary' t)
instance Agda.TypeChecking.Reduce.Instantiate ()
instance (Agda.TypeChecking.Reduce.Instantiate a, Agda.TypeChecking.Reduce.Instantiate b) => Agda.TypeChecking.Reduce.Instantiate (a, b)
instance (Agda.TypeChecking.Reduce.Instantiate a, Agda.TypeChecking.Reduce.Instantiate b, Agda.TypeChecking.Reduce.Instantiate c) => Agda.TypeChecking.Reduce.Instantiate (a, b, c)
instance Agda.TypeChecking.Reduce.Instantiate Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Reduce.Instantiate t => Agda.TypeChecking.Reduce.Instantiate (Agda.Syntax.Internal.Type' t)
instance Agda.TypeChecking.Reduce.Instantiate Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Reduce.Instantiate t => Agda.TypeChecking.Reduce.Instantiate (Agda.Syntax.Internal.PlusLevel' t)
instance Agda.TypeChecking.Reduce.Instantiate a => Agda.TypeChecking.Reduce.Instantiate (Agda.Syntax.Internal.Blocked a)
instance Agda.TypeChecking.Reduce.Instantiate Agda.Syntax.Internal.Blockers.Blocker
instance Agda.TypeChecking.Reduce.Instantiate Agda.Syntax.Internal.Sort
instance (Agda.TypeChecking.Reduce.Instantiate t, Agda.TypeChecking.Reduce.Instantiate e) => Agda.TypeChecking.Reduce.Instantiate (Agda.Syntax.Internal.Dom' t e)
instance Agda.TypeChecking.Reduce.Instantiate a => Agda.TypeChecking.Reduce.Instantiate (Agda.TypeChecking.Monad.Base.Closure a)
instance Agda.TypeChecking.Reduce.Instantiate Agda.TypeChecking.Monad.Base.Constraint
instance Agda.TypeChecking.Reduce.Instantiate Agda.TypeChecking.Monad.Base.CompareAs
instance Agda.TypeChecking.Reduce.Instantiate Agda.TypeChecking.Monad.Base.Candidate
instance Agda.TypeChecking.Reduce.Instantiate Agda.Syntax.Internal.EqualityView

module Agda.TypeChecking.Telescope

-- | Flatten telescope: <tt>(Γ : Tel) -&gt; [Type Γ]</tt>
flattenTel :: TermSubst a => Tele (Dom a) -> [Dom a]

-- | Turn a context into a flat telescope: all entries live in the whole
--   context. <tt> (Γ : Context) -&gt; [Type Γ] </tt>
flattenContext :: Context -> [ContextEntry]

-- | Order a flattened telescope in the correct dependeny order: Γ -&gt;
--   Permutation (Γ -&gt; Γ~)
--   
--   Since <tt>reorderTel tel</tt> uses free variable analysis of type in
--   <tt>tel</tt>, the telescope should be <a>normalise</a>d.
reorderTel :: [Dom Type] -> Maybe Permutation
reorderTel_ :: [Dom Type] -> Permutation

-- | Unflatten: turns a flattened telescope into a proper telescope. Must
--   be properly ordered.
unflattenTel :: [ArgName] -> [Dom Type] -> Telescope

-- | A variant of <a>unflattenTel</a> which takes the size of the last
--   argument as an argument.
unflattenTel' :: Int -> [ArgName] -> [Dom Type] -> Telescope

-- | Rename the variables in the telescope to the given names Precondition:
--   <tt>size xs == size tel</tt>.
renameTel :: [Maybe ArgName] -> Telescope -> Telescope

-- | Get the suggested names from a telescope
teleNames :: Telescope -> [ArgName]
teleArgNames :: Telescope -> [Arg ArgName]
teleArgs :: DeBruijn a => Tele (Dom t) -> [Arg a]
teleDoms :: DeBruijn a => Tele (Dom t) -> [Dom a]
teleNamedArgs :: DeBruijn a => Tele (Dom t) -> [NamedArg a]

-- | A variant of <a>teleNamedArgs</a> which takes the argument names (and
--   the argument info) from the first telescope and the variable names
--   from the second telescope.
--   
--   Precondition: the two telescopes have the same length.
tele2NamedArgs :: DeBruijn a => Telescope -> Telescope -> [NamedArg a]

-- | Split the telescope at the specified position.
splitTelescopeAt :: Int -> Telescope -> (Telescope, Telescope)

-- | Permute telescope: permutes or drops the types in the telescope
--   according to the given permutation. Assumes that the permutation
--   preserves the dependencies in the telescope.
--   
--   For example (Andreas, 2016-12-18, issue #2344): <tt> tel = (A : Set)
--   (X : _18 A) (i : Fin (_m_23 A X)) tel (de Bruijn) = 2:Set, 1:_18
--   </tt>0, 0:Fin(_m_23 <tt>1 </tt>0) flattenTel tel = 2:Set, 1:_18 <tt>0,
--   0:Fin(_m_23 </tt>1 <tt>0) |- [ Set, _18 </tt>2, Fin (_m_23 <tt>2
--   </tt>1) ] perm = 0,1,2 -&gt; 0,1 (picks the first two) renaming _ perm
--   = [var 0, var 1, error] -- THE WRONG RENAMING! renaming _ (flipP perm)
--   = [error, var 1, var 0] -- The correct renaming! apply to flattened
--   tel = ... |- [ Set, _18 <tt>1, Fin (_m_23 </tt>1 <tt>0) ] permute perm
--   it = ... |- [ Set, _18 </tt>1 ] unflatten (de Bruijn) = 1:Set, 0: _18
--   <tt>0 unflatten = (A : Set) (X : _18 A) </tt>
permuteTel :: Permutation -> Telescope -> Telescope

-- | Like <a>permuteTel</a>, but start with a context.
permuteContext :: Permutation -> Context -> Telescope

-- | Recursively computes dependencies of a set of variables in a given
--   telescope. Any dependencies outside of the telescope are ignored.
varDependencies :: Telescope -> IntSet -> IntSet

-- | Computes the set of variables in a telescope whose type depend on one
--   of the variables in the given set (including recursive dependencies).
--   Any dependencies outside of the telescope are ignored.
varDependents :: Telescope -> IntSet -> IntSet

-- | A telescope split in two.
data SplitTel
SplitTel :: Telescope -> Telescope -> Permutation -> SplitTel
[firstPart] :: SplitTel -> Telescope
[secondPart] :: SplitTel -> Telescope

-- | The permutation takes us from the original telescope to <tt>firstPart
--   ++ secondPart</tt>.
[splitPerm] :: SplitTel -> Permutation

-- | Split a telescope into the part that defines the given variables and
--   the part that doesn't.
--   
--   See <a>prop_splitTelescope</a>.
splitTelescope :: VarSet -> Telescope -> SplitTel

-- | As splitTelescope, but fails if any additional variables or reordering
--   would be needed to make the first part well-typed.
splitTelescopeExact :: [Int] -> Telescope -> Maybe SplitTel

-- | Try to instantiate one variable in the telescope (given by its de
--   Bruijn level) with the given value, returning the new telescope and a
--   substitution to the old one. Returns Nothing if the given value
--   depends (directly or indirectly) on the variable.
instantiateTelescope :: Telescope -> Int -> DeBruijnPattern -> Maybe (Telescope, PatternSubstitution, Permutation)

-- | Try to eta-expand one variable in the telescope (given by its de
--   Bruijn level)
expandTelescopeVar :: Telescope -> Int -> Telescope -> ConHead -> (Telescope, PatternSubstitution)

-- | Gather leading Πs of a type in a telescope.
telView :: (MonadReduce m, MonadAddContext m) => Type -> m TelView

-- | <tt>telViewUpTo n t</tt> takes off the first <tt>n</tt> function types
--   of <tt>t</tt>. Takes off all if <tt>n &lt; 0</tt>.
telViewUpTo :: (MonadReduce m, MonadAddContext m) => Int -> Type -> m TelView

-- | <tt>telViewUpTo' n p t</tt> takes off $t$ the first <tt>n</tt> (or
--   arbitrary many if <tt>n &lt; 0</tt>) function domains as long as they
--   satify <tt>p</tt>.
telViewUpTo' :: (MonadReduce m, MonadAddContext m) => Int -> (Dom Type -> Bool) -> Type -> m TelView
telViewPath :: PureTCM m => Type -> m TelView

-- | <tt>telViewUpToPath n t</tt> takes off $t$ the first <tt>n</tt> (or
--   arbitrary many if <tt>n &lt; 0</tt>) function domains or Path types.
--   
--   <pre>
--   telViewUpToPath n t = fst <a>$</a> telViewUpToPathBoundary'n t
--   </pre>
telViewUpToPath :: PureTCM m => Int -> Type -> m TelView

-- | <ul>
--   <li><i>[ (i,(x,y)) </i> ] = [(i=0) -&gt; x, (i=1) -&gt; y]</li>
--   </ul>
type Boundary = Boundary' (Term, Term)
type Boundary' a = [(Term, a)]

-- | Like <tt>telViewUpToPath</tt> but also returns the <tt>Boundary</tt>
--   expected by the Path types encountered. The boundary terms live in the
--   telescope given by the <tt>TelView</tt>. Each point of the boundary
--   has the type of the codomain of the Path type it got taken from, see
--   <tt>fullBoundary</tt>.
telViewUpToPathBoundary' :: PureTCM m => Int -> Type -> m (TelView, Boundary)
fullBoundary :: Telescope -> Boundary -> Boundary

-- | <tt>(TelV Γ b, [(i,t_i,u_i)]) &lt;- telViewUpToPathBoundary n a</tt>
--   Input: Δ ⊢ a Output: ΔΓ ⊢ b ΔΓ ⊢ i : I ΔΓ ⊢ [ (i=0) -&gt; t_i; (i=1)
--   -&gt; u_i ] : b
telViewUpToPathBoundary :: PureTCM m => Int -> Type -> m (TelView, Boundary)

-- | <tt>(TelV Γ b, [(i,t_i,u_i)]) &lt;- telViewUpToPathBoundaryP n a</tt>
--   Input: Δ ⊢ a Output: Δ.Γ ⊢ b Δ.Γ ⊢ T is the codomain of the PathP at
--   variable i Δ.Γ ⊢ i : I Δ.Γ ⊢ [ (i=0) -&gt; t_i; (i=1) -&gt; u_i ] : T
--   Useful to reconstruct IApplyP patterns after teleNamedArgs Γ.
telViewUpToPathBoundaryP :: PureTCM m => Int -> Type -> m (TelView, Boundary)
telViewPathBoundaryP :: PureTCM m => Type -> m (TelView, Boundary)

-- | <tt>teleElimsB args bs = es</tt> Input: Δ.Γ ⊢ args : Γ Δ.Γ ⊢ T is the
--   codomain of the PathP at variable i Δ.Γ ⊢ i : I Δ.Γ ⊢ bs = [ (i=0)
--   -&gt; t_i; (i=1) -&gt; u_i ] : T Output: Δ.Γ | PiPath Γ bs A ⊢ es : A
teleElims :: DeBruijn a => Telescope -> Boundary' (a, a) -> [Elim' a]

-- | Reduces <a>Type</a>.
pathViewAsPi :: PureTCM m => Type -> m (Either (Dom Type, Abs Type) Type)

-- | Reduces <a>Type</a>.
pathViewAsPi' :: PureTCM m => Type -> m (Either ((Dom Type, Abs Type), (Term, Term)) Type)
pathViewAsPi'whnf :: HasBuiltins m => m (Type -> Either ((Dom Type, Abs Type), (Term, Term)) Type)

-- | Returns <tt>Left (a,b)</tt> in case the type is <tt>Pi a b</tt> or
--   <tt>PathP b _ _</tt>. Assumes the <a>Type</a> is in whnf.
piOrPath :: HasBuiltins m => Type -> m (Either (Dom Type, Abs Type) Type)

-- | Assumes <a>Type</a> is in whnf.
telView'UpToPath :: Int -> Type -> TCM TelView
telView'Path :: Type -> TCM TelView
isPath :: PureTCM m => Type -> m (Maybe (Dom Type, Abs Type))
ifPath :: PureTCM m => Type -> (Dom Type -> Abs Type -> m a) -> (Type -> m a) -> m a
ifPathB :: PureTCM m => Type -> (Dom Type -> Abs Type -> m a) -> (Blocked Type -> m a) -> m a
ifNotPathB :: PureTCM m => Type -> (Blocked Type -> m a) -> (Dom Type -> Abs Type -> m a) -> m a
ifPiOrPathB :: PureTCM m => Type -> (Dom Type -> Abs Type -> m a) -> (Blocked Type -> m a) -> m a
ifNotPiOrPathB :: PureTCM m => Type -> (Blocked Type -> m a) -> (Dom Type -> Abs Type -> m a) -> m a
telePatterns :: DeBruijn a => Telescope -> Boundary -> [NamedArg (Pattern' a)]
telePatterns' :: DeBruijn a => (forall a. DeBruijn a => Telescope -> [NamedArg a]) -> Telescope -> Boundary -> [NamedArg (Pattern' a)]

-- | Decomposing a function type.
mustBePi :: MonadReduce m => Type -> m (Dom Type, Abs Type)

-- | If the given type is a <tt>Pi</tt>, pass its parts to the first
--   continuation. If not (or blocked), pass the reduced type to the second
--   continuation.
ifPi :: MonadReduce m => Term -> (Dom Type -> Abs Type -> m a) -> (Term -> m a) -> m a
ifPiB :: MonadReduce m => Term -> (Dom Type -> Abs Type -> m a) -> (Blocked Term -> m a) -> m a
ifPiTypeB :: MonadReduce m => Type -> (Dom Type -> Abs Type -> m a) -> (Blocked Type -> m a) -> m a

-- | If the given type is a <tt>Pi</tt>, pass its parts to the first
--   continuation. If not (or blocked), pass the reduced type to the second
--   continuation.
ifPiType :: MonadReduce m => Type -> (Dom Type -> Abs Type -> m a) -> (Type -> m a) -> m a

-- | If the given type is blocked or not a <tt>Pi</tt>, pass it reduced to
--   the first continuation. If it is a <tt>Pi</tt>, pass its parts to the
--   second continuation.
ifNotPi :: MonadReduce m => Term -> (Term -> m a) -> (Dom Type -> Abs Type -> m a) -> m a

-- | If the given type is blocked or not a <tt>Pi</tt>, pass it reduced to
--   the first continuation. If it is a <tt>Pi</tt>, pass its parts to the
--   second continuation.
ifNotPiType :: MonadReduce m => Type -> (Type -> m a) -> (Dom Type -> Abs Type -> m a) -> m a
ifNotPiOrPathType :: (MonadReduce tcm, HasBuiltins tcm) => Type -> (Type -> tcm a) -> (Dom Type -> Abs Type -> tcm a) -> tcm a
shouldBePath :: (PureTCM m, MonadBlock m, MonadTCError m) => Type -> m (Dom Type, Abs Type)
shouldBePi :: (PureTCM m, MonadBlock m, MonadTCError m) => Type -> m (Dom Type, Abs Type)
shouldBePiOrPath :: (PureTCM m, MonadBlock m, MonadTCError m) => Type -> m (Dom Type, Abs Type)

-- | A safe variant of <a>piApply</a>.
class PiApplyM a
piApplyM' :: (PiApplyM a, MonadReduce m, HasBuiltins m) => m Empty -> Type -> a -> m Type
piApplyM :: (PiApplyM a, MonadReduce m, HasBuiltins m) => Type -> a -> m Type

-- | Compute type arity
typeArity :: Type -> TCM Nat

-- | Fold a telescope into a monadic computation, adding variables to the
--   context at each step.
foldrTelescopeM :: MonadAddContext m => (Dom (ArgName, Type) -> m b -> m b) -> m b -> Telescope -> m b
instance Agda.TypeChecking.Telescope.PiApplyM Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Telescope.PiApplyM a => Agda.TypeChecking.Telescope.PiApplyM (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Telescope.PiApplyM a => Agda.TypeChecking.Telescope.PiApplyM (Agda.Syntax.Common.Named n a)
instance Agda.TypeChecking.Telescope.PiApplyM a => Agda.TypeChecking.Telescope.PiApplyM [a]


-- | A syntactic equality check that takes meta instantiations into
--   account, but does not reduce. It replaces <tt> (v, v') &lt;-
--   instantiateFull (v, v') v == v' </tt> by a more efficient routine
--   which only traverses and instantiates the terms as long as they are
--   equal.
module Agda.TypeChecking.SyntacticEquality

-- | Instantiate full as long as things are equal
class SynEq a

-- | Syntactic equality check for terms. If syntactic equality checking has
--   fuel left, then <a>checkSyntacticEquality</a> behaves as if it were
--   implemented in the following way (which does not match the given type
--   signature), only that <tt>v</tt> and <tt>v'</tt> are only fully
--   instantiated to the depth where they are equal (and the amount of fuel
--   is reduced by one unit in the failure branch): <tt>
--   checkSyntacticEquality v v' s f = do (v, v') &lt;- instantiateFull (v,
--   v') if v == v' then s v v' else f v v' </tt> If syntactic equality
--   checking does not have fuel left, then <a>checkSyntacticEquality</a>
--   instantiates the two terms and takes the failure branch.
--   
--   Note that in either case the returned values <tt>v</tt> and
--   <tt>v'</tt> cannot be <tt>MetaV</tt>s that are instantiated.
checkSyntacticEquality :: (Instantiate a, SynEq a, MonadReduce m) => a -> a -> (a -> a -> m b) -> (a -> a -> m b) -> m b

-- | Syntactic equality check for terms without checking remaining fuel.
checkSyntacticEquality' :: (Instantiate a, SynEq a, MonadReduce m) => a -> a -> (a -> a -> m b) -> (a -> a -> m b) -> m b

-- | Does the syntactic equality check have any remaining fuel?
syntacticEqualityFuelRemains :: MonadReduce m => m Bool
instance Agda.TypeChecking.SyntacticEquality.SynEq GHC.Types.Bool
instance Agda.TypeChecking.SyntacticEquality.SynEq Agda.Syntax.Internal.Term
instance Agda.TypeChecking.SyntacticEquality.SynEq Agda.Syntax.Internal.Level
instance Agda.TypeChecking.SyntacticEquality.SynEq Agda.Syntax.Internal.PlusLevel
instance Agda.TypeChecking.SyntacticEquality.SynEq Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.SyntacticEquality.SynEq Agda.Syntax.Internal.Type
instance Agda.TypeChecking.SyntacticEquality.SynEq a => Agda.TypeChecking.SyntacticEquality.SynEq [a]
instance (Agda.TypeChecking.SyntacticEquality.SynEq a, Agda.TypeChecking.SyntacticEquality.SynEq b) => Agda.TypeChecking.SyntacticEquality.SynEq (a, b)
instance Agda.TypeChecking.SyntacticEquality.SynEq a => Agda.TypeChecking.SyntacticEquality.SynEq (Agda.Syntax.Internal.Elim.Elim' a)
instance (Agda.TypeChecking.Substitute.Class.Subst a, Agda.TypeChecking.SyntacticEquality.SynEq a) => Agda.TypeChecking.SyntacticEquality.SynEq (Agda.Syntax.Internal.Abs a)
instance Agda.TypeChecking.SyntacticEquality.SynEq a => Agda.TypeChecking.SyntacticEquality.SynEq (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.SyntacticEquality.SynEq a => Agda.TypeChecking.SyntacticEquality.SynEq (Agda.Syntax.Internal.Dom a)
instance Agda.TypeChecking.SyntacticEquality.SynEq Agda.Syntax.Common.ArgInfo


-- | Tools to manipulate patterns in internal syntax in the TCM (type
--   checking monad).
module Agda.TypeChecking.Patterns.Internal

-- | Convert a term (from a dot pattern) to a DeBruijn pattern.
class TermToPattern a b
termToPattern :: TermToPattern a b => a -> TCM b
termToPattern :: (TermToPattern a b, TermToPattern a' b', Traversable f, a ~ f a', b ~ f b') => a -> TCM b
dotPatternsToPatterns :: forall a. DeBruijn (Pattern' a) => Pattern' a -> TCM (Pattern' a)
instance Agda.TypeChecking.Patterns.Internal.TermToPattern a b => Agda.TypeChecking.Patterns.Internal.TermToPattern [a] [b]
instance Agda.TypeChecking.Patterns.Internal.TermToPattern a b => Agda.TypeChecking.Patterns.Internal.TermToPattern (Agda.Syntax.Common.Arg a) (Agda.Syntax.Common.Arg b)
instance Agda.TypeChecking.Patterns.Internal.TermToPattern a b => Agda.TypeChecking.Patterns.Internal.TermToPattern (Agda.Syntax.Common.Named c a) (Agda.Syntax.Common.Named c b)
instance Agda.TypeChecking.Substitute.DeBruijn.DeBruijn (Agda.Syntax.Internal.Pattern' a) => Agda.TypeChecking.Patterns.Internal.TermToPattern Agda.Syntax.Internal.Term (Agda.Syntax.Internal.Pattern' a)

module Agda.TypeChecking.Level
data LevelKit
LevelKit :: Term -> (Term -> Term) -> (Term -> Term -> Term) -> Term -> QName -> QName -> QName -> QName -> LevelKit
[lvlType] :: LevelKit -> Term
[lvlSuc] :: LevelKit -> Term -> Term
[lvlMax] :: LevelKit -> Term -> Term -> Term
[lvlZero] :: LevelKit -> Term
[typeName] :: LevelKit -> QName
[sucName] :: LevelKit -> QName
[maxName] :: LevelKit -> QName
[zeroName] :: LevelKit -> QName

-- | Get the <a>primLevel</a> as a <a>Type</a>. Aborts if any of the level
--   BUILTINs is undefined.
levelType :: (HasBuiltins m, MonadTCError m) => m Type

-- | Get the <a>primLevel</a> as a <a>Type</a>. Unsafe, crashes if the
--   BUILTIN LEVEL is undefined.
levelType' :: HasBuiltins m => m Type
isLevelType :: PureTCM m => Type -> m Bool
builtinLevelKit :: HasBuiltins m => m LevelKit

-- | Raises an error if no level kit is available.
requireLevels :: (HasBuiltins m, MonadTCError m) => m LevelKit

-- | Checks whether level kit is fully available.
haveLevels :: HasBuiltins m => m Bool
unLevel :: HasBuiltins m => Term -> m Term
reallyUnLevelView :: HasBuiltins m => Level -> m Term
unlevelWithKit :: LevelKit -> Level -> Term
unConstV :: Term -> (Term -> Term) -> Integer -> Term
unPlusV :: (Term -> Term) -> PlusLevel -> Term
maybePrimCon :: TCM Term -> TCM (Maybe ConHead)
maybePrimDef :: TCM Term -> TCM (Maybe QName)
levelView :: PureTCM m => Term -> m Level
levelView' :: PureTCM m => Term -> m Level

-- | Given a level <tt>l</tt>, find the maximum constant <tt>n</tt> such
--   that <tt>l = n + l'</tt>
levelPlusView :: Level -> (Integer, Level)

-- | Given a level <tt>l</tt>, find the biggest constant <tt>n</tt> such
--   that <tt>n &lt;= l</tt>
levelLowerBound :: Level -> Integer

-- | Given a constant <tt>n</tt> and a level <tt>l</tt>, find the level
--   <tt>l'</tt> such that <tt>l = n + l'</tt> (or Nothing if there is no
--   such level). Operates on levels in canonical form.
subLevel :: Integer -> Level -> Maybe Level

-- | Given two levels <tt>a</tt> and <tt>b</tt>, try to decompose the first
--   one as <tt>a = a' ⊔ b</tt> (for the minimal value of <tt>a'</tt>).
levelMaxDiff :: Level -> Level -> Maybe Level

-- | A <tt>SingleLevel</tt> is a <tt>Level</tt> that cannot be further
--   decomposed as a maximum <tt>a ⊔ b</tt>.
data SingleLevel' t
SingleClosed :: Integer -> SingleLevel' t
SinglePlus :: PlusLevel' t -> SingleLevel' t
type SingleLevel = SingleLevel' Term
unSingleLevel :: SingleLevel' t -> Level' t

-- | Return the maximum of the given <tt>SingleLevel</tt>s
unSingleLevels :: [SingleLevel] -> Level
levelMaxView :: Level' t -> List1 (SingleLevel' t)
singleLevelView :: Level' t -> Maybe (SingleLevel' t)
instance Data.Traversable.Traversable Agda.TypeChecking.Level.SingleLevel'
instance Data.Foldable.Foldable Agda.TypeChecking.Level.SingleLevel'
instance GHC.Base.Functor Agda.TypeChecking.Level.SingleLevel'
instance GHC.Show.Show t => GHC.Show.Show (Agda.TypeChecking.Level.SingleLevel' t)
instance GHC.Classes.Eq Agda.TypeChecking.Level.SingleLevel
instance Agda.TypeChecking.Substitute.Class.Subst t => Agda.TypeChecking.Substitute.Class.Subst (Agda.TypeChecking.Level.SingleLevel' t)
instance Agda.TypeChecking.Free.Lazy.Free t => Agda.TypeChecking.Free.Lazy.Free (Agda.TypeChecking.Level.SingleLevel' t)

module Agda.TypeChecking.LevelConstraints

-- | <tt>simplifyLevelConstraint c cs</tt> turns an <tt>c</tt> into an
--   equality constraint if it is an inequality constraint and the reverse
--   inequality is contained in <tt>cs</tt>.
--   
--   The constraints don't necessarily have to live in the same context,
--   but they do need to be universally quanitfied over the context. This
--   function takes care of renaming variables when checking for matches.
simplifyLevelConstraint :: Constraint -> [Constraint] -> Maybe [Constraint]
instance GHC.Classes.Eq Agda.TypeChecking.LevelConstraints.Leq
instance GHC.Show.Show Agda.TypeChecking.LevelConstraints.Leq

module Agda.TypeChecking.Level.Solve

-- | Run the given action. At the end take all new metavariables of type
--   level for which the only constraints are upper bounds on the level,
--   and instantiate them to the lowest level.
defaultOpenLevelsToZero :: (PureTCM m, MonadMetaSolver m) => m a -> m a
defaultLevelsToZero :: forall m. (PureTCM m, MonadMetaSolver m) => LocalMetaStore -> m ()


-- | Free variable check that reduces the subject to make certain variables
--   not free. Used when pruning metavariables in
--   Agda.TypeChecking.MetaVars.Occurs.
module Agda.TypeChecking.Free.Reduce
class (PrecomputeFreeVars a, Subst a) => ForceNotFree a

-- | Try to enforce a set of variables not occurring in a given type.
--   Returns a possibly reduced version of the type and for each of the
--   given variables whether it is either not free, or maybe free depending
--   on some metavariables.
forceNotFree :: (ForceNotFree a, Reduce a, MonadReduce m) => IntSet -> a -> m (IntMap IsFree, a)

-- | Checks if the given term contains any free variables that are in the
--   given set of variables, possibly reducing the term in the process.
--   Returns `Right Nothing` if there are such variables, `Right (Just v')`
--   if there are none (where v' is the possibly reduced version of the
--   given term) or `Left b` if the problem is blocked on a meta.
reallyFree :: (MonadReduce m, Reduce a, ForceNotFree a) => IntSet -> a -> m (Either Blocked_ (Maybe a))

-- | A variable can either not occur (<a>NotFree</a>) or it does occur
--   (<a>MaybeFree</a>). In the latter case, the occurrence may disappear
--   depending on the instantiation of some set of metas.
data IsFree
MaybeFree :: MetaSet -> IsFree
NotFree :: IsFree
instance GHC.Show.Show Agda.TypeChecking.Free.Reduce.IsFree
instance GHC.Classes.Eq Agda.TypeChecking.Free.Reduce.IsFree
instance (Agda.TypeChecking.Reduce.Reduce a, Agda.TypeChecking.Free.Reduce.ForceNotFree a) => Agda.TypeChecking.Free.Reduce.ForceNotFree (Agda.Syntax.Common.Arg a)
instance (Agda.TypeChecking.Reduce.Reduce a, Agda.TypeChecking.Free.Reduce.ForceNotFree a, Agda.TypeChecking.Substitute.Class.TermSubst a) => Agda.TypeChecking.Free.Reduce.ForceNotFree (Agda.Syntax.Internal.Dom a)
instance (Agda.TypeChecking.Reduce.Reduce a, Agda.TypeChecking.Free.Reduce.ForceNotFree a) => Agda.TypeChecking.Free.Reduce.ForceNotFree (Agda.Syntax.Internal.Abs a)
instance Agda.TypeChecking.Free.Reduce.ForceNotFree a => Agda.TypeChecking.Free.Reduce.ForceNotFree [a]
instance (Agda.TypeChecking.Reduce.Reduce a, Agda.TypeChecking.Free.Reduce.ForceNotFree a) => Agda.TypeChecking.Free.Reduce.ForceNotFree (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.TypeChecking.Free.Reduce.ForceNotFree Agda.Syntax.Internal.Type
instance Agda.TypeChecking.Free.Reduce.ForceNotFree Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Free.Reduce.ForceNotFree Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Free.Reduce.ForceNotFree Agda.Syntax.Internal.PlusLevel
instance Agda.TypeChecking.Free.Reduce.ForceNotFree Agda.Syntax.Internal.Sort


-- | Tools for <a>DisplayTerm</a> and <a>DisplayForm</a>.
module Agda.TypeChecking.DisplayForm

-- | Find a matching display form for <tt>q es</tt>. In essence this tries
--   to rewrite <tt>q es</tt> with any display form <tt>q ps --&gt; dt</tt>
--   and returns the instantiated <tt>dt</tt> if successful. First match
--   wins.
displayForm :: MonadDisplayForm m => QName -> Elims -> m (Maybe DisplayTerm)
instance Agda.TypeChecking.DisplayForm.SubstWithOrigin a => Agda.TypeChecking.DisplayForm.SubstWithOrigin [a]
instance (Agda.TypeChecking.DisplayForm.SubstWithOrigin a, Agda.TypeChecking.DisplayForm.SubstWithOrigin (Agda.Syntax.Common.Arg a)) => Agda.TypeChecking.DisplayForm.SubstWithOrigin (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.TypeChecking.DisplayForm.SubstWithOrigin (Agda.Syntax.Common.Arg Agda.Syntax.Internal.Term)
instance Agda.TypeChecking.DisplayForm.SubstWithOrigin Agda.Syntax.Internal.Term
instance Agda.TypeChecking.DisplayForm.SubstWithOrigin Agda.TypeChecking.Monad.Base.DisplayTerm
instance Agda.TypeChecking.DisplayForm.SubstWithOrigin (Agda.Syntax.Common.Arg Agda.TypeChecking.Monad.Base.DisplayTerm)
instance Agda.TypeChecking.DisplayForm.Match a => Agda.TypeChecking.DisplayForm.Match [a]
instance Agda.TypeChecking.DisplayForm.Match a => Agda.TypeChecking.DisplayForm.Match (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.DisplayForm.Match a => Agda.TypeChecking.DisplayForm.Match (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.TypeChecking.DisplayForm.Match Agda.Syntax.Internal.Term
instance Agda.TypeChecking.DisplayForm.Match Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.DisplayForm.Match Agda.Syntax.Internal.Level

module Agda.TypeChecking.DeadCode

-- | Run before serialisation to remove data that's not reachable from the
--   public interface. We do not compute reachable data precisely, because
--   that would be very expensive, mainly because of rewrite rules. The
--   following things are assumed to be "roots": - public names (for
--   definitions and pattern synonyms) - definitions marked as primitive -
--   definitions with COMPILE pragma - all parameter sections (because all
--   sections go into interfaces!) (see also issues #6931 and #7382) -
--   local builtins - all rewrite rules We only ever prune dead
--   metavariables and definitions. The reachable ones are returned from
--   this function.
eliminateDeadCode :: ScopeInfo -> TCM (RemoteMetaStore, Definitions)

module Agda.TypeChecking.CompiledClause.Match
matchCompiled :: CompiledClauses -> MaybeReducedArgs -> ReduceM (Reduced (Blocked Args) Term)

-- | <tt>matchCompiledE c es</tt> takes a function given by case tree
--   <tt>c</tt> and and a spine <tt>es</tt> and tries to apply the function
--   to <tt>es</tt>.
matchCompiledE :: CompiledClauses -> MaybeReducedElims -> ReduceM (Reduced (Blocked Elims) Term)

-- | A stack entry is a triple consisting of 1. the part of the case tree
--   to continue matching, 2. the current argument vector, and 3. a patch
--   function taking the current argument vector back to the original
--   argument vector.
type Frame = (CompiledClauses, MaybeReducedElims, Elims -> Elims)
type Stack = [Frame]

-- | <tt>match'</tt> tries to solve the matching problems on the
--   <tt>Stack</tt>. In each iteration, the top problem is removed and
--   handled.
--   
--   If the top problem was a <tt>Done</tt>, we succeed.
--   
--   If the top problem was a <tt>Case n</tt> and the <tt>n</tt>th argument
--   of the problem is not a constructor or literal, we are stuck, thus,
--   fail.
--   
--   If we have a branch for the constructor/literal, we put it on the
--   stack to continue. If we do not have a branch, we fall through to the
--   next problem, which should be the corresponding catch-all branch.
--   
--   An empty stack is an exception that can come only from an incomplete
--   function definition.
match' :: Stack -> ReduceM (Reduced (Blocked Elims) Term)


-- | Checking for recursion:
--   
--   <ul>
--   <li>We detect truly (co)recursive definitions by computing the
--   dependency graph and checking for cycles.</li>
--   <li>This is inexpensive and let us skip the termination check when
--   there's no (co)recursion</li>
--   </ul>
--   
--   Original contribution by Andrea Vezzosi (sanzhiyan). This
--   implementation by Andreas.
module Agda.Termination.RecCheck

-- | The mutual block we are checking.
--   
--   The functions are numbered according to their order of appearance in
--   this set.
type MutualNames = Set QName

-- | Given a list of formally mutually recursive functions, check for
--   actual recursive calls in the bodies of these functions. Returns the
--   actually recursive functions as strongly connected components.
--   
--   As a side effect, update the <a>clauseRecursive</a> field in the
--   clauses belonging to the given functions.
recursive :: Set QName -> TCM [MutualNames]

-- | <tt>anysDef names a</tt> returns all definitions from <tt>names</tt>
--   that are used in <tt>a</tt>.
anyDefs :: GetDefs a => (QName -> Bool) -> a -> TCM (Set QName)

module Agda.Syntax.Translation.ReflectedToAbstract
type Vars = [(Name, Type)]
type MonadReflectedToAbstract m = (MonadReader Vars m, MonadFresh NameId m, MonadError TCErr m, MonadTCEnv m, ReadTCState m, HasOptions m, HasBuiltins m, HasConstInfo m)

-- | Adds a new unique name to the current context. NOTE: See
--   <tt>chooseName</tt> in
--   <tt>Agda.Syntax.Translation.AbstractToConcrete</tt> for similar logic.
--   NOTE: See <tt>freshConcreteName</tt> in
--   <tt>Agda.Syntax.Scope.Monad</tt> also for similar logic.
withName :: MonadReflectedToAbstract m => String -> (Name -> m a) -> m a
withVar :: MonadReflectedToAbstract m => String -> Type -> (Name -> m a) -> m a
withNames :: MonadReflectedToAbstract m => [String] -> ([Name] -> m a) -> m a
withVars :: MonadReflectedToAbstract m => [(String, Type)] -> ([Name] -> m a) -> m a

-- | Returns the name and type of the variable with the given de Bruijn
--   index.
askVar :: MonadReflectedToAbstract m => Int -> m (Maybe (Name, Type))
askName :: MonadReflectedToAbstract m => Int -> m (Maybe Name)
class ToAbstract r where {
    type AbsOfRef r;
}
toAbstract :: (ToAbstract r, MonadReflectedToAbstract m) => r -> m (AbsOfRef r)
toAbstract :: (ToAbstract r, Traversable t, ToAbstract s, t s ~ r, t (AbsOfRef s) ~ AbsOfRef r) => MonadReflectedToAbstract m => r -> m (AbsOfRef r)

-- | Translate reflected syntax to abstract, using the names from the
--   current typechecking context.
toAbstract_ :: (ToAbstract r, MonadFresh NameId m, MonadError TCErr m, MonadTCEnv m, ReadTCState m, HasOptions m, HasBuiltins m, HasConstInfo m) => r -> m (AbsOfRef r)

-- | Drop implicit arguments unless --show-implicit is on.
toAbstractWithoutImplicit :: (ToAbstract r, MonadFresh NameId m, MonadError TCErr m, MonadTCEnv m, ReadTCState m, HasOptions m, HasBuiltins m, HasConstInfo m) => r -> m (AbsOfRef r)
mkMetaInfo :: ReadTCState m => m MetaInfo
mkDef :: HasConstInfo m => QName -> m Expr
mkApp :: Expr -> Expr -> Expr
mkVar :: MonadReflectedToAbstract m => Int -> m (Name, Type)
mkVarName :: MonadReflectedToAbstract m => Int -> m Name
annotatePattern :: MonadReflectedToAbstract m => Int -> Type -> Pattern -> m Pattern

-- | Check that all variables in the telescope are bound in the left-hand
--   side. Since we check the telescope by attaching type annotations to
--   the pattern variables there needs to be somewhere to put the
--   annotation. Also, since the lhs is where the variables are actually
--   bound, missing a binding for a variable that's used later in the
--   telescope causes unbound variable panic (see #5044).
checkClauseTelescopeBindings :: MonadReflectedToAbstract m => [(Text, Arg Type)] -> [Arg Pattern] -> m ()
instance Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract r => Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract (Agda.Syntax.Common.Named name r)
instance Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract r => Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract (Agda.Syntax.Common.Arg r)
instance Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract r => Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract [Agda.Syntax.Common.Arg r]
instance (Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract r, Agda.Syntax.Translation.ReflectedToAbstract.AbsOfRef r GHC.Types.~ Agda.Syntax.Abstract.Expr) => Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract (Agda.Syntax.Internal.Dom r, Agda.Syntax.Abstract.Name.Name)
instance Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract (Agda.Syntax.Abstract.Expr, Agda.Syntax.Reflected.Elim)
instance Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract (Agda.Syntax.Abstract.Expr, Agda.Syntax.Reflected.Elims)
instance Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract r => Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract (Agda.Syntax.Reflected.Abs r)
instance Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract Agda.Syntax.Literal.Literal
instance Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract Agda.Syntax.Reflected.Term
instance Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract Agda.Syntax.Reflected.Sort
instance Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract Agda.Syntax.Reflected.Pattern
instance Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract (Agda.Syntax.Abstract.Name.QNamed Agda.Syntax.Reflected.Clause)
instance Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract [Agda.Syntax.Abstract.Name.QNamed Agda.Syntax.Reflected.Clause]
instance Agda.Syntax.Translation.ReflectedToAbstract.ToAbstract (Agda.Utils.List1.List1 (Agda.Syntax.Abstract.Name.QNamed Agda.Syntax.Reflected.Clause))


-- | Translating from internal syntax to abstract syntax. Enables nice
--   pretty printing of internal syntax.
--   
--   TODO
--   
--   <ul>
--   <li>numbers on metas</li>
--   <li>fake dependent functions to independent functions</li>
--   <li>meta parameters</li>
--   <li>shadowing</li>
--   </ul>
module Agda.Syntax.Translation.InternalToAbstract
class Reify i where {
    type ReifiesTo i;
}
reify :: (Reify i, MonadReify m) => i -> m (ReifiesTo i)
reifyWhen :: (Reify i, MonadReify m) => Bool -> i -> m (ReifiesTo i)
type MonadReify m = (PureTCM m, MonadInteractionPoints m, MonadFresh NameId m)
data NamedClause

-- | Also tracks whether module parameters should be dropped from the
--   patterns.
NamedClause :: QName -> Bool -> Clause -> NamedClause

-- | Assumes that pattern variables have been added to the context already.
--   Picks pattern variable names from context.
reifyPatterns :: MonadReify m => [NamedArg DeBruijnPattern] -> m [NamedArg Pattern]

-- | Like <tt>reify</tt> but instantiates blocking metas, useful for
--   reporting.
reifyUnblocked :: Reify i => i -> TCM (ReifiesTo i)

-- | <tt>blankNotInScope e</tt> replaces variables in expression <tt>e</tt>
--   with <tt>_</tt> if they are currently not in scope.
blankNotInScope :: (MonadTCEnv m, MonadDebug m, BlankVars a) => a -> m a

-- | <tt>reifyDisplayFormP</tt> tries to recursively rewrite a lhs with a
--   display form.
--   
--   Note: we are not necessarily in the empty context upon entry!
reifyDisplayFormP :: forall m. MonadReify m => QName -> Patterns -> Patterns -> m (QName, Patterns)
instance Agda.Syntax.Translation.InternalToAbstract.BlankVars Agda.Syntax.Abstract.Clause
instance Agda.Syntax.Translation.InternalToAbstract.BlankVars Agda.Syntax.Abstract.Expr
instance Agda.Syntax.Translation.InternalToAbstract.Binder Agda.Syntax.Abstract.LHS
instance Agda.Syntax.Translation.InternalToAbstract.Binder Agda.Syntax.Abstract.LHSCore
instance Agda.Syntax.Translation.InternalToAbstract.Binder Agda.Syntax.Abstract.Pattern
instance Agda.Syntax.Translation.InternalToAbstract.Binder a => Agda.Syntax.Translation.InternalToAbstract.Binder (Agda.Syntax.Abstract.Binder' a)
instance Agda.Syntax.Translation.InternalToAbstract.Binder Agda.Syntax.Abstract.LamBinding
instance Agda.Syntax.Translation.InternalToAbstract.Binder Agda.Syntax.Abstract.TypedBinding
instance Agda.Syntax.Translation.InternalToAbstract.Binder Agda.Syntax.Abstract.BindName
instance Agda.Syntax.Translation.InternalToAbstract.Binder Agda.Syntax.Abstract.LetBinding
instance Agda.Syntax.Translation.InternalToAbstract.Binder a => Agda.Syntax.Translation.InternalToAbstract.Binder (Agda.Syntax.Concrete.FieldAssignment' a)
instance Agda.Syntax.Translation.InternalToAbstract.Binder a => Agda.Syntax.Translation.InternalToAbstract.Binder (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Translation.InternalToAbstract.Binder a => Agda.Syntax.Translation.InternalToAbstract.Binder (Agda.Syntax.Common.Named x a)
instance Agda.Syntax.Translation.InternalToAbstract.Binder a => Agda.Syntax.Translation.InternalToAbstract.Binder [a]
instance Agda.Syntax.Translation.InternalToAbstract.Binder a => Agda.Syntax.Translation.InternalToAbstract.Binder (Agda.Utils.List1.List1 a)
instance Agda.Syntax.Translation.InternalToAbstract.Binder a => Agda.Syntax.Translation.InternalToAbstract.Binder (GHC.Maybe.Maybe a)
instance (Agda.Syntax.Translation.InternalToAbstract.Binder a, Agda.Syntax.Translation.InternalToAbstract.Binder b) => Agda.Syntax.Translation.InternalToAbstract.Binder (a, b)
instance Agda.Syntax.Translation.InternalToAbstract.BlankVars a => Agda.Syntax.Translation.InternalToAbstract.BlankVars (Agda.Syntax.Common.Arg a)
instance Agda.Syntax.Translation.InternalToAbstract.BlankVars a => Agda.Syntax.Translation.InternalToAbstract.BlankVars (Agda.Syntax.Common.Named s a)
instance Agda.Syntax.Translation.InternalToAbstract.BlankVars a => Agda.Syntax.Translation.InternalToAbstract.BlankVars [a]
instance Agda.Syntax.Translation.InternalToAbstract.BlankVars a => Agda.Syntax.Translation.InternalToAbstract.BlankVars (Agda.Utils.List1.List1 a)
instance Agda.Syntax.Translation.InternalToAbstract.BlankVars a => Agda.Syntax.Translation.InternalToAbstract.BlankVars (Agda.Syntax.Concrete.FieldAssignment' a)
instance (Agda.Syntax.Translation.InternalToAbstract.BlankVars a, Agda.Syntax.Translation.InternalToAbstract.BlankVars b) => Agda.Syntax.Translation.InternalToAbstract.BlankVars (a, b)
instance (Agda.Syntax.Translation.InternalToAbstract.BlankVars a, Agda.Syntax.Translation.InternalToAbstract.BlankVars b) => Agda.Syntax.Translation.InternalToAbstract.BlankVars (Data.Either.Either a b)
instance Agda.Syntax.Translation.InternalToAbstract.BlankVars Agda.Syntax.Abstract.ProblemEq
instance Agda.Syntax.Translation.InternalToAbstract.BlankVars Agda.Syntax.Abstract.LHS
instance Agda.Syntax.Translation.InternalToAbstract.BlankVars Agda.Syntax.Abstract.LHSCore
instance Agda.Syntax.Translation.InternalToAbstract.BlankVars Agda.Syntax.Abstract.Pattern
instance Agda.Syntax.Translation.InternalToAbstract.BlankVars Agda.Syntax.Abstract.Name.ModuleName
instance Agda.Syntax.Translation.InternalToAbstract.BlankVars Agda.Syntax.Abstract.RHS
instance Agda.Syntax.Translation.InternalToAbstract.BlankVars Agda.Syntax.Abstract.LamBinding
instance Agda.Syntax.Translation.InternalToAbstract.BlankVars Agda.Syntax.Abstract.TypedBinding
instance (GHC.Classes.Ord k, GHC.Base.Monoid v) => GHC.Base.Semigroup (Agda.Syntax.Translation.InternalToAbstract.MonoidMap k v)
instance (GHC.Classes.Ord k, GHC.Base.Monoid v) => GHC.Base.Monoid (Agda.Syntax.Translation.InternalToAbstract.MonoidMap k v)
instance Agda.Syntax.Translation.InternalToAbstract.Reify (Agda.Syntax.Abstract.Name.QNamed Agda.Syntax.Internal.Clause)
instance Agda.Syntax.Translation.InternalToAbstract.Reify Agda.Syntax.Translation.InternalToAbstract.NamedClause
instance Agda.Syntax.Translation.InternalToAbstract.Reify GHC.Types.Bool
instance Agda.Syntax.Translation.InternalToAbstract.Reify GHC.Types.Char
instance Agda.Syntax.Translation.InternalToAbstract.Reify Agda.Syntax.Abstract.Name.Name
instance Agda.Syntax.Translation.InternalToAbstract.Reify Agda.Syntax.Abstract.Expr
instance Agda.Syntax.Translation.InternalToAbstract.Reify Agda.Syntax.Common.MetaId
instance Agda.Syntax.Translation.InternalToAbstract.Reify Agda.TypeChecking.Monad.Base.DisplayTerm
instance Agda.Syntax.Translation.InternalToAbstract.Reify Agda.Syntax.Literal.Literal
instance Agda.Syntax.Translation.InternalToAbstract.Reify Agda.Syntax.Internal.Term
instance Agda.Syntax.Translation.InternalToAbstract.Reify i => Agda.Syntax.Translation.InternalToAbstract.Reify (Agda.Syntax.Common.Named n i)
instance Agda.Syntax.Translation.InternalToAbstract.Reify i => Agda.Syntax.Translation.InternalToAbstract.Reify (Agda.Syntax.Common.Arg i)
instance Agda.Syntax.Translation.InternalToAbstract.Reify (Agda.Syntax.Abstract.Name.QNamed Agda.TypeChecking.Monad.Base.System)
instance Agda.Syntax.Translation.InternalToAbstract.Reify Agda.Syntax.Internal.Type
instance Agda.Syntax.Translation.InternalToAbstract.Reify Agda.Syntax.Internal.Sort
instance Agda.Syntax.Translation.InternalToAbstract.Reify Agda.Syntax.Internal.Level
instance (Agda.TypeChecking.Free.Lazy.Free i, Agda.Syntax.Translation.InternalToAbstract.Reify i) => Agda.Syntax.Translation.InternalToAbstract.Reify (Agda.Syntax.Internal.Abs i)
instance Agda.Syntax.Translation.InternalToAbstract.Reify Agda.Syntax.Internal.Telescope
instance Agda.Syntax.Translation.InternalToAbstract.Reify i => Agda.Syntax.Translation.InternalToAbstract.Reify (Agda.Syntax.Internal.Dom i)
instance Agda.Syntax.Translation.InternalToAbstract.Reify i => Agda.Syntax.Translation.InternalToAbstract.Reify (Agda.Syntax.Internal.Elim.Elim' i)
instance Agda.Syntax.Translation.InternalToAbstract.Reify i => Agda.Syntax.Translation.InternalToAbstract.Reify [i]
instance (Agda.Syntax.Translation.InternalToAbstract.Reify i1, Agda.Syntax.Translation.InternalToAbstract.Reify i2) => Agda.Syntax.Translation.InternalToAbstract.Reify (i1, i2)
instance (Agda.Syntax.Translation.InternalToAbstract.Reify i1, Agda.Syntax.Translation.InternalToAbstract.Reify i2, Agda.Syntax.Translation.InternalToAbstract.Reify i3) => Agda.Syntax.Translation.InternalToAbstract.Reify (i1, i2, i3)
instance (Agda.Syntax.Translation.InternalToAbstract.Reify i1, Agda.Syntax.Translation.InternalToAbstract.Reify i2, Agda.Syntax.Translation.InternalToAbstract.Reify i3, Agda.Syntax.Translation.InternalToAbstract.Reify i4) => Agda.Syntax.Translation.InternalToAbstract.Reify (i1, i2, i3, i4)

module Agda.TypeChecking.Pretty
type Doc = Doc
class PrettyTCM a
prettyTCM :: (PrettyTCM a, MonadPretty m) => a -> m Doc
type MonadPretty m = MonadAbsToCon m
newtype PrettyContext
PrettyContext :: Context -> PrettyContext

-- | Pairing something with a node (for printing only).
data WithNode n a
WithNode :: n -> a -> WithNode n a

-- | Pretty-print something paired with a (printable) node. | This
--   intermediate typeclass exists to avoid UndecidableInstances.
class PrettyTCMWithNode a
prettyTCMWithNode :: (PrettyTCMWithNode a, PrettyTCM n, MonadPretty m) => WithNode n a -> m Doc
pretty :: (Applicative m, Pretty a) => a -> m Doc
text :: Applicative m => String -> m Doc
(<?>) :: Applicative m => m Doc -> m Doc -> m Doc
infixl 6 <?>
comma :: Applicative m => m Doc
colon :: Applicative m => m Doc
parens :: Functor m => m Doc -> m Doc
(<+>) :: Applicative m => m Doc -> m Doc -> m Doc
infixl 6 <+>
hcat :: (Applicative m, Foldable t) => t (m Doc) -> m Doc
hsep :: (Applicative m, Foldable t) => t (m Doc) -> m Doc
vcat :: (Applicative m, Foldable t) => t (m Doc) -> m Doc
vsep :: (Applicative m, Foldable t) => t (m Doc) -> m Doc
braces :: Functor m => m Doc -> m Doc
brackets :: Functor m => m Doc -> m Doc
equals :: Applicative m => m Doc
quotes :: Functor m => m Doc -> m Doc
doubleQuotes :: Functor m => m Doc -> m Doc
nest :: Functor m => Int -> m Doc -> m Doc
hang :: Applicative m => m Doc -> Int -> m Doc -> m Doc
punctuate :: (Applicative m, Semigroup (m Doc), Foldable t) => m Doc -> t (m Doc) -> [m Doc]
($$) :: Applicative m => m Doc -> m Doc -> m Doc
infixl 5 $$
($+$) :: Applicative m => m Doc -> m Doc -> m Doc
infixl 5 $+$
sep :: (Applicative m, Foldable t) => t (m Doc) -> m Doc
fsep :: (Applicative m, Foldable t) => t (m Doc) -> m Doc
dbraces :: Functor m => m Doc -> m Doc
prettyA :: (ToConcrete a, Pretty (ConOfAbs a), MonadAbsToCon m) => a -> m Doc

-- | <a>prettyList</a> without the brackets.
prettyList_ :: (Applicative m, Semigroup (m Doc), Foldable t) => t (m Doc) -> m Doc
pshow :: (Applicative m, Show a) => a -> m Doc

-- | Comma-separated list in brackets.
prettyList :: (Applicative m, Semigroup (m Doc), Foldable t) => t (m Doc) -> m Doc
pwords :: Applicative m => String -> [m Doc]
fwords :: Applicative m => String -> m Doc
parensNonEmpty :: Functor m => m Doc -> m Doc
multiLineText :: Applicative m => String -> m Doc
prettyAs :: (ToConcrete a, ConOfAbs a ~ [ce], Pretty ce, MonadAbsToCon m) => a -> m Doc
superscript :: Applicative m => Int -> m Doc

-- | Pretty print with a given context precedence
prettyTCMCtx :: (PrettyTCM a, MonadPretty m) => Precedence -> a -> m Doc
prettyR :: (ToAbstract r, PrettyTCM (AbsOfRef r), MonadPretty m, MonadError TCErr m) => r -> m Doc

-- | Proper pretty printing of patterns:
prettyTCMPatterns :: MonadPretty m => [NamedArg DeBruijnPattern] -> m [Doc]
prettyTCMPatternList :: MonadPretty m => [NamedArg DeBruijnPattern] -> m Doc

-- | The class of semigroups (types with an associative binary operation).
--   
--   Instances should satisfy the following:
--   
--   <ul>
--   <li><i>Associativity</i> <tt>x <a>&lt;&gt;</a> (y <a>&lt;&gt;</a> z) =
--   (x <a>&lt;&gt;</a> y) <a>&lt;&gt;</a> z</tt></li>
--   </ul>
--   
--   You can alternatively define <a>sconcat</a> instead of
--   (<a>&lt;&gt;</a>), in which case the laws are:
--   
--   <ul>
--   <li><i>Unit</i> <tt><a>sconcat</a> (<a>pure</a> x) = x</tt></li>
--   <li><i>Multiplication</i> <tt><a>sconcat</a> (<a>join</a> xss) =
--   <a>sconcat</a> (<a>fmap</a> <a>sconcat</a> xss)</tt></li>
--   </ul>
class () => Semigroup a

-- | An associative operation.
--   
--   <pre>
--   &gt;&gt;&gt; [1,2,3] &lt;&gt; [4,5,6]
--   [1,2,3,4,5,6]
--   </pre>
(<>) :: Semigroup a => a -> a -> a
infixr 6 <>

-- | The function <a>runAbsToCon</a> can target any monad that satisfies
--   the constraints of <a>MonadAbsToCon</a>.
type MonadAbsToCon m = (MonadFresh NameId m, MonadInteractionPoints m, MonadStConcreteNames m, HasOptions m, PureTCM m, IsString (m Doc), Null (m Doc), Semigroup (m Doc))
instance Agda.TypeChecking.Pretty.PrettyTCMWithNode Agda.TypeChecking.Positivity.Occurrence.Occurrence
instance (Agda.TypeChecking.Pretty.PrettyTCM n, Agda.TypeChecking.Pretty.PrettyTCMWithNode e) => Agda.TypeChecking.Pretty.PrettyTCM (Agda.Utils.Graph.AdjacencyMap.Unidirectional.Graph n e)
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Pretty.PrettyContext
instance Agda.TypeChecking.Pretty.PrettyTCM GHC.Base.String
instance Agda.TypeChecking.Pretty.PrettyTCM GHC.Types.Bool
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Concrete.Name.Name
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Concrete.Name.QName
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.TopLevelModuleName.TopLevelModuleName
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.Comparison
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Literal.Literal
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Common.Nat
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Common.ProblemId
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Position.Range
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.CheckpointId
instance Agda.TypeChecking.Pretty.PrettyTCM a => Agda.TypeChecking.Pretty.PrettyTCM (Agda.TypeChecking.Monad.Base.Closure a)
instance Agda.TypeChecking.Pretty.PrettyTCM a => Agda.TypeChecking.Pretty.PrettyTCM [a]
instance Agda.TypeChecking.Pretty.PrettyTCM a => Agda.TypeChecking.Pretty.PrettyTCM (GHC.Maybe.Maybe a)
instance (Agda.TypeChecking.Pretty.PrettyTCM a, Agda.TypeChecking.Pretty.PrettyTCM b) => Agda.TypeChecking.Pretty.PrettyTCM (a, b)
instance (Agda.TypeChecking.Pretty.PrettyTCM a, Agda.TypeChecking.Pretty.PrettyTCM b, Agda.TypeChecking.Pretty.PrettyTCM c) => Agda.TypeChecking.Pretty.PrettyTCM (a, b, c)
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Internal.Type
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.DisplayTerm
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Translation.InternalToAbstract.NamedClause
instance Agda.TypeChecking.Pretty.PrettyTCM (Agda.Syntax.Abstract.Name.QNamed Agda.Syntax.Internal.Clause)
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Pretty.PrettyTCM (Agda.Syntax.Common.Named_ Agda.Syntax.Internal.Term)
instance Agda.TypeChecking.Pretty.PrettyTCM (Agda.Syntax.Common.Arg Agda.Syntax.Internal.Term)
instance Agda.TypeChecking.Pretty.PrettyTCM (Agda.Syntax.Common.Arg Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.Pretty.PrettyTCM (Agda.Syntax.Common.Arg GHC.Types.Bool)
instance Agda.TypeChecking.Pretty.PrettyTCM (Agda.Syntax.Common.Arg GHC.Base.String)
instance Agda.TypeChecking.Pretty.PrettyTCM (Agda.Syntax.Common.Arg Agda.Syntax.Abstract.Expr)
instance Agda.TypeChecking.Pretty.PrettyTCM (Agda.Syntax.Common.NamedArg Agda.Syntax.Abstract.Expr)
instance Agda.TypeChecking.Pretty.PrettyTCM (Agda.Syntax.Common.NamedArg Agda.Syntax.Internal.Term)
instance Agda.TypeChecking.Pretty.PrettyTCM (Agda.Syntax.Internal.Dom Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.Types.ContextEntry
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Utils.Permutation.Permutation
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.Polarity
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.IsForced
instance (Agda.Syntax.Common.Pretty.Pretty a, Agda.TypeChecking.Pretty.PrettyTCM a, Agda.TypeChecking.Substitute.Class.EndoSubst a) => Agda.TypeChecking.Pretty.PrettyTCM (Agda.Syntax.Internal.Substitution' a)
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Internal.Clause
instance Agda.TypeChecking.Pretty.PrettyTCM a => Agda.TypeChecking.Pretty.PrettyTCM (Agda.TypeChecking.Monad.Base.Judgement a)
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Common.MetaId
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.NamedMeta
instance Agda.TypeChecking.Pretty.PrettyTCM a => Agda.TypeChecking.Pretty.PrettyTCM (Agda.Syntax.Internal.Blocked a)
instance (Agda.TypeChecking.Pretty.PrettyTCM k, Agda.TypeChecking.Pretty.PrettyTCM v) => Agda.TypeChecking.Pretty.PrettyTCM (Data.Map.Internal.Map k v)
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Internal.Elim
instance Agda.TypeChecking.Pretty.PrettyTCM a => Agda.TypeChecking.Pretty.PrettyTCM (Agda.TypeChecking.Monad.Base.MaybeReduced a)
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Internal.EqualityView
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Abstract.Expr
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Abstract.TypedBinding
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Abstract.Pattern
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Common.Relevance
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Common.Quantity
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Common.Erased
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Common.Modality
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Internal.Blockers.Blocker
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.CompareAs
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.TypeCheckingProblem
instance Agda.TypeChecking.Pretty.PrettyTCM a => Agda.TypeChecking.Pretty.PrettyTCM (Agda.Syntax.Common.WithHiding a)
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Abstract.Name.Name
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Abstract.Name.QName
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Abstract.Name.ModuleName
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Scope.Base.AbstractName
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Internal.ConHead
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Internal.Telescope
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Internal.DBPatVar
instance Agda.TypeChecking.Pretty.PrettyTCM a => Agda.TypeChecking.Pretty.PrettyTCM (Agda.Syntax.Internal.Pattern' a)
instance Agda.TypeChecking.Pretty.PrettyTCM (Agda.Syntax.Internal.Elim.Elim' Agda.TypeChecking.Monad.Base.DisplayTerm)
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.NLPat
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.NLPType
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.NLPSort
instance Agda.TypeChecking.Pretty.PrettyTCM (Agda.Syntax.Internal.Elim.Elim' Agda.TypeChecking.Monad.Base.NLPat)
instance Agda.TypeChecking.Pretty.PrettyTCM (Agda.Syntax.Internal.Type' Agda.TypeChecking.Monad.Base.NLPat)
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.RewriteRule
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Positivity.Occurrence.Occurrence
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Coverage.SplitTree.SplitTag
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.Candidate
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.DiscrimTree.Types.Key
instance Agda.TypeChecking.Pretty.PrettyTCM a => Agda.TypeChecking.Pretty.PrettyTCM (Data.Set.Internal.Set a)
instance Agda.TypeChecking.Pretty.PrettyTCM a => Agda.TypeChecking.Pretty.PrettyTCM (Agda.TypeChecking.DiscrimTree.Types.DiscrimTree a)
instance GHC.Base.Semigroup (Agda.TypeChecking.Monad.Base.TCM Agda.TypeChecking.Pretty.Doc)

module Agda.TypeChecking.Telescope.Path

-- | In an ambient context Γ, <tt>telePiPath f lams Δ t bs</tt> builds a
--   type that can be <tt>telViewPathBoundaryP'ed</tt> into (TelV Δ t,
--   bs'). Γ.Δ ⊢ t bs = [(i,u_i)] Δ = Δ0,(i : I),Δ1 ∀ b ∈ {0,1}. Γ.Δ0 |
--   lams Δ1 (u_i .b) : (telePiPath f Δ1 t bs)(i = b) -- kinda: see lams Γ
--   ⊢ telePiPath f Δ t bs
telePiPath :: (Abs Type -> Abs Type) -> ([Arg ArgName] -> Term -> Term) -> Telescope -> Type -> Boundary -> TCM Type

-- | <tt>telePiPath_ Δ t [(i,u)]</tt> Δ ⊢ t i ∈ Δ Δ ⊢ u_b : t for b ∈ {0,1}
telePiPath_ :: Telescope -> Type -> [(Int, (Term, Term))] -> TCM Type

-- | arity of the type, including both Pi and Path. Does not reduce the
--   type.
arityPiPath :: Type -> TCM Int

-- | Collect the interval copattern variables as list of de Bruijn indices.
class IApplyVars p
iApplyVars :: IApplyVars p => p -> [Int]

-- | Check whether a type is the built-in interval type.
isInterval :: (MonadTCM m, MonadReduce m) => Type -> m Bool
instance Agda.TypeChecking.Substitute.DeBruijn.DeBruijn a => Agda.TypeChecking.Telescope.Path.IApplyVars (Agda.Syntax.Internal.Pattern' a)
instance Agda.TypeChecking.Telescope.Path.IApplyVars p => Agda.TypeChecking.Telescope.Path.IApplyVars (Agda.Syntax.Common.NamedArg p)
instance Agda.TypeChecking.Telescope.Path.IApplyVars p => Agda.TypeChecking.Telescope.Path.IApplyVars [p]

module Agda.TypeChecking.SizedTypes.WarshallSolver
type Graph r f a = Graph (Node r f) a
type Edge' r f a = Edge (Node r f) a
type Key r f = Edge' r f ()
type Nodes r f = Nodes (Node r f)
type LabelledEdge r f = Edge' r f Label
src :: Edge n e -> n
dest :: Edge n e -> n
lookupEdge :: Ord n => Graph n e -> n -> n -> Maybe e
graphToList :: Graph n e -> [Edge n e]
graphFromList :: Ord n => [Edge n e] -> Graph n e
insertEdge :: (Ord n, MeetSemiLattice e, Top e) => Edge n e -> Graph n e -> Graph n e

-- | Compute list of edges that start in a given node.
outgoing :: (Ord r, Ord f) => Graph r f a -> Node r f -> [Edge' r f a]

-- | Compute list of edges that target a given node.
--   
--   Note: expensive for unidirectional graph representations.
incoming :: (Ord r, Ord f) => Graph r f a -> Node r f -> [Edge' r f a]

-- | <tt>Set.foldl</tt> does not exist in legacy versions of the
--   <tt>containers</tt> package.
setFoldl :: (b -> a -> b) -> b -> Set a -> b

-- | Floyd-Warshall algorithm.
transClos :: forall n a. (Ord n, Dioid a) => Graph n a -> Graph n a
data Weight
Offset :: Offset -> Weight
Infinity :: Weight

-- | Test for negativity, used to detect negative cycles.
class Negative a
negative :: Negative a => a -> Bool

-- | Going from <tt>Lt</tt> to <tt>Le</tt> is <tt>pred</tt>, going from
--   <tt>Le</tt> to <tt>Lt</tt> is <tt>succ</tt>.
--   
--   <tt>X --(R,n)--&gt; Y</tt> means <tt>X (R) Y + n</tt>. [ ... if
--   <tt>n</tt> positive and <tt>X + (-n) (R) Y</tt> if <tt>n</tt>
--   negative. ]
data Label
Label :: Cmp -> Offset -> Label
[lcmp] :: Label -> Cmp
[loffset] :: Label -> Offset

-- | Nodes not connected.
LInf :: Label

-- | Convert a label to a weight, decrementing in case of <a>Lt</a>.
toWeight :: Label -> Weight
data Node rigid flex
NodeZero :: Node rigid flex
NodeInfty :: Node rigid flex
NodeRigid :: rigid -> Node rigid flex
NodeFlex :: flex -> Node rigid flex
isFlexNode :: Node rigid flex -> Maybe flex
isZeroNode :: Node rigid flex -> Bool
isInftyNode :: Node rigid flex -> Bool
nodeToSizeExpr :: Node rigid flex -> SizeExpr' rigid flex

-- | A graph forest.
type Graphs r f a = [Graph r f a]
emptyGraphs :: Graphs r f a

-- | Split a list of graphs <tt>gs</tt> into those that mention node
--   <tt>n</tt> and those that do not. If <tt>n</tt> is zero or infinity,
--   we regard it as "not mentioned".
mentions :: (Ord r, Ord f) => Node r f -> Graphs r f a -> (Graphs r f a, Graphs r f a)

-- | Add an edge to a graph forest. Graphs that share a node with the edge
--   are joined.
addEdge :: (Ord r, Ord f, MeetSemiLattice a, Top a) => Edge' r f a -> Graphs r f a -> Graphs r f a

-- | Reflexive closure. Add edges <tt>0 -&gt; n -&gt; n -&gt; oo</tt> for
--   all nodes <tt>n</tt>.
reflClos :: (Ord r, Ord f, Dioid a) => Set (Node r f) -> Graph r f a -> Graph r f a

-- | <tt>h <a>implies</a> g</tt> if any edge in <tt>g</tt> between rigids
--   and constants is implied by a corresponding edge in <tt>h</tt>, which
--   means that the edge in <tt>g</tt> carries at most the information of
--   the one in <tt>h</tt>.
--   
--   Application: Constraint implication: Constraints are compatible with
--   hypotheses.
implies :: (Ord r, Ord f, Pretty r, Pretty f, Pretty a, Top a, Ord a, Negative a) => Graph r f a -> Graph r f a -> Bool
nodeFromSizeExpr :: SizeExpr' rigid flex -> (Node rigid flex, Offset)
edgeFromConstraint :: Constraint' rigid flex -> LabelledEdge rigid flex

-- | Build a graph from list of simplified constraints.
graphFromConstraints :: (Ord rigid, Ord flex) => [Constraint' rigid flex] -> Graph rigid flex Label

-- | Build a graph from list of simplified constraints.
graphsFromConstraints :: (Ord rigid, Ord flex) => [Constraint' rigid flex] -> Graphs rigid flex Label

-- | Error messages produced by the solver.
type Error = TCM Doc
type CTrans r f = Constraint' r f -> Either Error [Constraint' r f]
simplify1 :: (Pretty f, Pretty r, Eq r) => CTrans r f -> CTrans r f
type Hyp = Constraint
type Hyp' = Constraint'
type HypGraph r f = Graph r f Label
hypGraph :: (Ord rigid, Ord flex, Pretty rigid, Pretty flex) => Set rigid -> [Hyp' rigid flex] -> Either Error (HypGraph rigid flex)
hypConn :: (Ord r, Ord f) => HypGraph r f -> Node r f -> Node r f -> Label
simplifyWithHypotheses :: (Ord rigid, Ord flex, Pretty rigid, Pretty flex) => HypGraph rigid flex -> [Constraint' rigid flex] -> Either Error [Constraint' rigid flex]
type ConGraph r f = Graph r f Label
constraintGraph :: (Ord r, Ord f, Pretty r, Pretty f) => [Constraint' r f] -> HypGraph r f -> Either Error (ConGraph r f)
type ConGraphs r f = Graphs r f Label
constraintGraphs :: (Ord r, Ord f, Pretty r, Pretty f) => [Constraint' r f] -> HypGraph r f -> Either Error ([f], ConGraphs r f)

-- | If we have an edge <tt>X + n &lt;= X</tt> (with n &gt;= 0), we must
--   set <tt>X = oo</tt>.
infinityFlexs :: (Ord r, Ord f) => ConGraph r f -> ([f], ConGraph r f)
class SetToInfty f a
setToInfty :: SetToInfty f a => [f] -> a -> a

-- | Lower or upper bound for a flexible variable
type Bound r f = Map f (Set (SizeExpr' r f))
emptyBound :: Bound r f
data Bounds r f
Bounds :: Bound r f -> Bound r f -> Set f -> Bounds r f
[lowerBounds] :: Bounds r f -> Bound r f
[upperBounds] :: Bounds r f -> Bound r f

-- | These metas are &lt; ∞.
[mustBeFinite] :: Bounds r f -> Set f

-- | Compute a lower bound for a flexible from an edge.
edgeToLowerBound :: LabelledEdge r f -> Maybe (f, SizeExpr' r f)

-- | Compute an upper bound for a flexible from an edge.
edgeToUpperBound :: LabelledEdge r f -> Maybe (f, Cmp, SizeExpr' r f)

-- | Compute the lower bounds for all flexibles in a graph.
graphToLowerBounds :: (Ord r, Ord f) => [LabelledEdge r f] -> Bound r f

-- | Compute the upper bounds for all flexibles in a graph.
graphToUpperBounds :: (Ord r, Ord f) => [LabelledEdge r f] -> (Bound r f, Set f)

-- | Compute the bounds for all flexibles in a graph.
bounds :: (Ord r, Ord f) => ConGraph r f -> Bounds r f

-- | Compute the relative minima in a set of nodes (those that do not have
--   a predecessor in the set).
smallest :: (Ord r, Ord f) => HypGraph r f -> [Node r f] -> [Node r f]

-- | Compute the relative maxima in a set of nodes (those that do not have
--   a successor in the set).
largest :: (Ord r, Ord f) => HypGraph r f -> [Node r f] -> [Node r f]

-- | Given source nodes n1,n2,... find all target nodes m1,m2, such that
--   for all j, there are edges n_i --l_ij--&gt; m_j for all i. Return
--   these edges as a map from target notes to a list of edges. We assume
--   the graph is reflexive-transitive.
commonSuccs :: (Ord r, Ord f) => Graph r f a -> [Node r f] -> Map (Node r f) [Edge' r f a]

-- | Given target nodes m1,m2,... find all source nodes n1,n2, such that
--   for all j, there are edges n_i --l_ij--&gt; m_j for all i. Return
--   these edges as a map from target notes to a list of edges. We assume
--   the graph is reflexive-transitive.
commonPreds :: (Ord r, Ord f) => Graph r f a -> [Node r f] -> Map (Node r f) [Edge' r f a]

-- | Compute the sup of two different rigids or a rigid and a constant.
lub' :: forall r f. (Ord r, Ord f, Pretty r, Pretty f, Show r, Show f) => HypGraph r f -> (Node r f, Offset) -> (Node r f, Offset) -> Maybe (SizeExpr' r f)

-- | Compute the inf of two different rigids or a rigid and a constant.
glb' :: forall r f. (Ord r, Ord f, Pretty r, Pretty f, Show r, Show f) => HypGraph r f -> (Node r f, Offset) -> (Node r f, Offset) -> Maybe (SizeExpr' r f)

-- | Compute the least upper bound (sup).
lub :: (Ord r, Ord f, Pretty r, Pretty f, Show r, Show f) => HypGraph r f -> SizeExpr' r f -> SizeExpr' r f -> Maybe (SizeExpr' r f)

-- | Compute the greatest lower bound (inf) of size expressions relative to
--   a hypotheses graph.
glb :: (Ord r, Ord f, Pretty r, Pretty f, Show r, Show f) => HypGraph r f -> SizeExpr' r f -> SizeExpr' r f -> Maybe (SizeExpr' r f)
findRigidBelow :: (Ord r, Ord f) => HypGraph r f -> SizeExpr' r f -> Maybe (SizeExpr' r f)
solveGraph :: forall r f. (Ord r, Ord f, Pretty r, Pretty f, PrettyTCM f, Show r, Show f) => Polarities f -> HypGraph r f -> ConGraph r f -> Either Error (Solution r f)

-- | Solve a forest of constraint graphs relative to a hypotheses graph.
--   Concatenate individual solutions.
solveGraphs :: (Ord r, Ord f, Pretty r, Pretty f, PrettyTCM f, Show r, Show f) => Polarities f -> HypGraph r f -> ConGraphs r f -> Either Error (Solution r f)

-- | Check that after substitution of the solution, constraints are implied
--   by hypotheses.
verifySolution :: (Ord r, Ord f, Pretty r, Pretty f, Show r, Show f) => HypGraph r f -> [Constraint' r f] -> Solution r f -> Either Error ()

-- | Iterate solver until no more metas can be solved.
--   
--   This might trigger a (wanted) error on the second iteration (see Issue
--   2096) which would otherwise go unnoticed.
iterateSolver :: (Ord r, Ord f, Pretty r, Pretty f, PrettyTCM f, Show r, Show f) => Polarities f -> HypGraph r f -> [Constraint' r f] -> Solution r f -> Either Error (Solution r f)
testSuccs :: Ord f => Map (Node [Char] f) [Edge' [Char] f Label]
testLub :: (Pretty f, Ord f, Show f) => Maybe (SizeExpr' [Char] f)
instance GHC.Show.Show Agda.TypeChecking.SizedTypes.WarshallSolver.Weight
instance GHC.Classes.Eq Agda.TypeChecking.SizedTypes.WarshallSolver.Weight
instance GHC.Show.Show Agda.TypeChecking.SizedTypes.WarshallSolver.Label
instance (GHC.Classes.Ord rigid, GHC.Classes.Ord flex) => GHC.Classes.Ord (Agda.TypeChecking.SizedTypes.WarshallSolver.Node rigid flex)
instance (GHC.Classes.Eq rigid, GHC.Classes.Eq flex) => GHC.Classes.Eq (Agda.TypeChecking.SizedTypes.WarshallSolver.Node rigid flex)
instance (GHC.Show.Show rigid, GHC.Show.Show flex) => GHC.Show.Show (Agda.TypeChecking.SizedTypes.WarshallSolver.Node rigid flex)
instance GHC.Classes.Eq f => Agda.TypeChecking.SizedTypes.WarshallSolver.SetToInfty f (Agda.TypeChecking.SizedTypes.WarshallSolver.Node r f)
instance GHC.Classes.Eq f => Agda.TypeChecking.SizedTypes.WarshallSolver.SetToInfty f (Agda.TypeChecking.SizedTypes.WarshallSolver.Edge' r f a)
instance (GHC.Classes.Ord r, GHC.Classes.Ord f) => Agda.TypeChecking.SizedTypes.WarshallSolver.SetToInfty f (Agda.TypeChecking.SizedTypes.WarshallSolver.ConGraph r f)
instance (GHC.Classes.Ord r, GHC.Classes.Ord f, Agda.TypeChecking.SizedTypes.WarshallSolver.Negative a) => Agda.TypeChecking.SizedTypes.WarshallSolver.Negative (Agda.TypeChecking.SizedTypes.WarshallSolver.Graphs r f a)
instance (GHC.Classes.Ord r, GHC.Classes.Ord f, Agda.TypeChecking.SizedTypes.WarshallSolver.Negative a) => Agda.TypeChecking.SizedTypes.WarshallSolver.Negative (Agda.TypeChecking.SizedTypes.WarshallSolver.Graph r f a)
instance Agda.TypeChecking.SizedTypes.WarshallSolver.Negative a => Agda.TypeChecking.SizedTypes.WarshallSolver.Negative (Agda.TypeChecking.SizedTypes.WarshallSolver.Edge' r f a)
instance (GHC.Classes.Ord r, GHC.Classes.Ord f, Agda.TypeChecking.SizedTypes.Utils.MeetSemiLattice a) => Agda.TypeChecking.SizedTypes.Utils.MeetSemiLattice (Agda.TypeChecking.SizedTypes.WarshallSolver.Edge' r f a)
instance (GHC.Classes.Ord r, GHC.Classes.Ord f, Agda.TypeChecking.SizedTypes.Utils.Top a) => Agda.TypeChecking.SizedTypes.Utils.Top (Agda.TypeChecking.SizedTypes.WarshallSolver.Edge' r f a)
instance (GHC.Classes.Ord r, GHC.Classes.Ord f, Agda.TypeChecking.SizedTypes.Utils.Dioid a) => Agda.TypeChecking.SizedTypes.Utils.Dioid (Agda.TypeChecking.SizedTypes.WarshallSolver.Edge' r f a)
instance (Agda.Syntax.Common.Pretty.Pretty rigid, Agda.Syntax.Common.Pretty.Pretty flex) => Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.SizedTypes.WarshallSolver.Node rigid flex)
instance Agda.TypeChecking.SizedTypes.WarshallSolver.Negative Agda.TypeChecking.SizedTypes.WarshallSolver.Label
instance GHC.Classes.Eq Agda.TypeChecking.SizedTypes.WarshallSolver.Label
instance GHC.Classes.Ord Agda.TypeChecking.SizedTypes.WarshallSolver.Label
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.SizedTypes.WarshallSolver.Label
instance Agda.TypeChecking.SizedTypes.Utils.MeetSemiLattice Agda.TypeChecking.SizedTypes.WarshallSolver.Label
instance Agda.TypeChecking.SizedTypes.Utils.Top Agda.TypeChecking.SizedTypes.WarshallSolver.Label
instance Agda.TypeChecking.SizedTypes.Utils.Dioid Agda.TypeChecking.SizedTypes.WarshallSolver.Label
instance Agda.TypeChecking.SizedTypes.Utils.Plus (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' r f) Agda.TypeChecking.SizedTypes.WarshallSolver.Label (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' r f)
instance Agda.TypeChecking.SizedTypes.WarshallSolver.Negative GHC.Types.Int
instance Agda.TypeChecking.SizedTypes.WarshallSolver.Negative Agda.TypeChecking.SizedTypes.Syntax.Offset
instance Agda.TypeChecking.SizedTypes.WarshallSolver.Negative Agda.TypeChecking.SizedTypes.WarshallSolver.Weight
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.SizedTypes.WarshallSolver.Weight
instance GHC.Classes.Ord Agda.TypeChecking.SizedTypes.WarshallSolver.Weight
instance Agda.TypeChecking.SizedTypes.Utils.MeetSemiLattice Agda.TypeChecking.SizedTypes.WarshallSolver.Weight
instance Agda.TypeChecking.SizedTypes.Utils.Top Agda.TypeChecking.SizedTypes.WarshallSolver.Weight
instance GHC.Enum.Enum Agda.TypeChecking.SizedTypes.WarshallSolver.Weight
instance GHC.Num.Num Agda.TypeChecking.SizedTypes.WarshallSolver.Weight
instance Agda.TypeChecking.SizedTypes.Utils.Plus Agda.TypeChecking.SizedTypes.WarshallSolver.Weight Agda.TypeChecking.SizedTypes.Syntax.Offset Agda.TypeChecking.SizedTypes.WarshallSolver.Weight
instance Agda.TypeChecking.SizedTypes.Utils.Dioid Agda.TypeChecking.SizedTypes.WarshallSolver.Weight
instance Agda.TypeChecking.SizedTypes.Utils.Plus Agda.TypeChecking.SizedTypes.Syntax.Offset Agda.TypeChecking.SizedTypes.WarshallSolver.Weight Agda.TypeChecking.SizedTypes.WarshallSolver.Weight
instance Agda.TypeChecking.SizedTypes.Utils.Plus (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' r f) Agda.TypeChecking.SizedTypes.WarshallSolver.Weight (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' r f)

module Agda.TypeChecking.SizedTypes.Pretty

-- | Turn a size expression into a term.
unSizeExpr :: HasBuiltins m => DBSizeExpr -> m Term
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.SizedTypes.Syntax.SizeMeta
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.SizedTypes.Syntax.SizeConstraint
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.SizedTypes.Syntax.HypSizeConstraint

module Agda.TypeChecking.Rules.Display
checkDisplayPragma :: QName -> [NamedArg Pattern] -> Expr -> TCM ()

module Agda.TypeChecking.Pretty.Call
sayWhere :: MonadPretty m => HasRange a => a -> m Doc -> m Doc
sayWhen :: MonadPretty m => Range -> Maybe (Closure Call) -> m Doc -> m Doc
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.CallInfo
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.Call


-- | Tools to manipulate patterns in abstract syntax in the TCM (type
--   checking monad).
module Agda.TypeChecking.Patterns.Abstract

-- | Expand literal integer pattern into suc/zero constructor patterns.
expandLitPattern :: (MonadError TCErr m, MonadTCEnv m, ReadTCState m, HasBuiltins m) => Pattern -> m Pattern

-- | Expand away (deeply) all pattern synonyms in a pattern.
expandPatternSynonyms' :: forall e. Pattern' e -> TCM (Pattern' e)
class ExpandPatternSynonyms a
expandPatternSynonyms :: ExpandPatternSynonyms a => a -> TCM a
expandPatternSynonyms :: (ExpandPatternSynonyms a, Traversable f, ExpandPatternSynonyms b, f b ~ a) => a -> TCM a
instance Agda.TypeChecking.Patterns.Abstract.ExpandPatternSynonyms a => Agda.TypeChecking.Patterns.Abstract.ExpandPatternSynonyms (GHC.Maybe.Maybe a)
instance Agda.TypeChecking.Patterns.Abstract.ExpandPatternSynonyms a => Agda.TypeChecking.Patterns.Abstract.ExpandPatternSynonyms [a]
instance Agda.TypeChecking.Patterns.Abstract.ExpandPatternSynonyms a => Agda.TypeChecking.Patterns.Abstract.ExpandPatternSynonyms (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Patterns.Abstract.ExpandPatternSynonyms a => Agda.TypeChecking.Patterns.Abstract.ExpandPatternSynonyms (Agda.Syntax.Common.Named n a)
instance Agda.TypeChecking.Patterns.Abstract.ExpandPatternSynonyms a => Agda.TypeChecking.Patterns.Abstract.ExpandPatternSynonyms (Agda.Syntax.Concrete.FieldAssignment' a)
instance Agda.TypeChecking.Patterns.Abstract.ExpandPatternSynonyms (Agda.Syntax.Abstract.Pattern' e)

module Agda.TypeChecking.Opacity

-- | Ensure that opaque blocks defined in the current module have saturated
--   unfolding sets.
saturateOpaqueBlocks :: forall m. (MonadTCState m, ReadTCState m, MonadFresh OpaqueId m, MonadDebug m, MonadTrace m, MonadWarning m, MonadIO m) => m ()

-- | Decide whether or not a definition is reducible. Returns <a>True</a>
--   if the definition <i>can</i> step.
isAccessibleDef :: TCEnv -> TCState -> Definition -> Bool

-- | Will the given <a>QName</a> have a proper definition, or will it be
--   wrapped in an <a>AbstractDefn</a>?
hasAccessibleDef :: (ReadTCState m, MonadTCEnv m, HasConstInfo m) => QName -> m Bool


-- | EDSL to construct terms without touching De Bruijn indices.
--   
--   e.g. given t, u :: Term, Γ ⊢ t, u : A, we can build "λ f. f t u" like
--   this:
--   
--   runNames [] $ do -- <tt>open</tt> binds <tt>t</tt> and <tt>u</tt> to
--   computations that know how to weaken themselves in -- an extended
--   context
--   
--   <ul>
--   <li><i>t,u</i> &lt;- mapM open [t,u]</li>
--   </ul>
--   
--   <ul>
--   <li>- <tt>lam</tt> gives the illusion of HOAS by providing f as a
--   computation.</li>
--   <li>- It also extends the internal context with the name "f", so
--   that</li>
--   <li>- <tt>t</tt> and <tt>u</tt> will get weakened in the body.</li>
--   <li>- We apply f with the (<a>@</a>) combinator from
--   Agda.TypeChecking.Primitive.</li>
--   </ul>
--   
--   lam "f" $ f -&gt; f <a>@</a> t <a>@</a> u
module Agda.TypeChecking.Names
newtype NamesT m a
NamesT :: ReaderT Names m a -> NamesT m a
[unName] :: NamesT m a -> ReaderT Names m a

-- | A list of variable names from a context.
type Names = [String]
runNamesT :: Names -> NamesT m a -> m a
runNames :: Names -> NamesT Fail a -> a
currentCxt :: Monad m => NamesT m Names

-- | <tt>cxtSubst Γ</tt> returns the substitution needed to go from Γ to
--   the current context.
--   
--   Fails if <tt>Γ</tt> is not a subcontext of the current one.
cxtSubst :: MonadFail m => Names -> NamesT m (Substitution' a)

-- | <tt>inCxt Γ t</tt> takes a <tt>t</tt> in context <tt>Γ</tt> and
--   produce an action that will return <tt>t</tt> weakened to the current
--   context.
--   
--   Fails whenever <tt>cxtSubst Γ</tt> would.
inCxt :: (MonadFail m, Subst a) => Names -> a -> NamesT m a

-- | Closed terms
cl' :: Applicative m => a -> NamesT m a
cl :: Monad m => m a -> NamesT m a

-- | Open terms in the current context.
open :: (MonadFail m, Subst a) => a -> NamesT m (NamesT m a)

-- | Monadic actions standing for variables.
--   
--   <tt>b</tt> is quantified over so the same variable can be used e.g.
--   both as a pattern and as an expression.
type Var m = forall b. (Subst b, DeBruijn b) => NamesT m b

-- | <tt>bind n f</tt> provides <tt>f</tt> with a fresh variable, which can
--   be used in any extended context.
--   
--   Returns an <tt>Abs</tt> which binds the extra variable.
bind :: MonadFail m => ArgName -> ((forall b. (Subst b, DeBruijn b) => NamesT m b) -> NamesT m a) -> NamesT m (Abs a)

-- | Like <tt>bind</tt> but returns a bare term.
bind' :: MonadFail m => ArgName -> ((forall b. (Subst b, DeBruijn b) => NamesT m b) -> NamesT m a) -> NamesT m a
glam :: MonadFail m => ArgInfo -> ArgName -> (NamesT m Term -> NamesT m Term) -> NamesT m Term
lam :: MonadFail m => ArgName -> (NamesT m Term -> NamesT m Term) -> NamesT m Term
ilam :: MonadFail m => ArgName -> (NamesT m Term -> NamesT m Term) -> NamesT m Term
data AbsN a
AbsN :: [ArgName] -> a -> AbsN a
[absNName] :: AbsN a -> [ArgName]
[unAbsN] :: AbsN a -> a

-- | Will crash on <tt>NoAbs</tt>
toAbsN :: Abs (AbsN a) -> AbsN a
absAppN :: Subst a => AbsN a -> [SubstArg a] -> a
type ArgVars m = (forall b. (Subst b, DeBruijn b) => [NamesT m (Arg b)])
type Vars m = (forall b. (Subst b, DeBruijn b) => [NamesT m b])
bindN :: MonadFail m => [ArgName] -> (Vars m -> NamesT m a) -> NamesT m (AbsN a)
bindNArg :: MonadFail m => [Arg ArgName] -> (ArgVars m -> NamesT m a) -> NamesT m (AbsN a)
type Vars1 m = (forall b. (Subst b, DeBruijn b) => List1 (NamesT m b))
bindN1 :: MonadFail m => List1 ArgName -> (Vars1 m -> NamesT m a) -> NamesT m (AbsN a)
glamN :: (Functor m, MonadFail m) => [Arg ArgName] -> (NamesT m Args -> NamesT m Term) -> NamesT m Term
applyN :: (Monad m, Subst a) => NamesT m (AbsN a) -> [NamesT m (SubstArg a)] -> NamesT m a
applyN' :: (Monad m, Subst a) => NamesT m (AbsN a) -> NamesT m [SubstArg a] -> NamesT m a
abstractN :: (MonadFail m, Abstract a) => NamesT m Telescope -> (Vars m -> NamesT m a) -> NamesT m a
abstractT :: (MonadFail m, Abstract a) => String -> NamesT m Type -> (Var m -> NamesT m a) -> NamesT m a
lamTel :: Monad m => NamesT m (Abs [Term]) -> NamesT m [Term]
appTel :: Monad m => NamesT m [Term] -> NamesT m Term -> NamesT m [Term]
instance (Agda.TypeChecking.Monad.Builtin.HasBuiltins m, Agda.TypeChecking.Monad.Signature.HasConstInfo m, Agda.TypeChecking.Monad.Context.MonadAddContext m, Agda.TypeChecking.Monad.Base.MonadReduce m) => Agda.TypeChecking.Monad.Pure.PureTCM (Agda.TypeChecking.Names.NamesT m)
instance Agda.TypeChecking.Monad.Signature.HasConstInfo m => Agda.TypeChecking.Monad.Signature.HasConstInfo (Agda.TypeChecking.Names.NamesT m)
instance Agda.TypeChecking.Monad.Context.MonadAddContext m => Agda.TypeChecking.Monad.Context.MonadAddContext (Agda.TypeChecking.Names.NamesT m)
instance Control.Monad.Error.Class.MonadError e m => Control.Monad.Error.Class.MonadError e (Agda.TypeChecking.Names.NamesT m)
instance Agda.TypeChecking.Monad.Base.MonadReduce m => Agda.TypeChecking.Monad.Base.MonadReduce (Agda.TypeChecking.Names.NamesT m)
instance Agda.TypeChecking.Monad.Base.ReadTCState m => Agda.TypeChecking.Monad.Base.ReadTCState (Agda.TypeChecking.Names.NamesT m)
instance Agda.TypeChecking.Monad.Base.MonadTCM m => Agda.TypeChecking.Monad.Base.MonadTCM (Agda.TypeChecking.Names.NamesT m)
instance Agda.TypeChecking.Monad.Base.MonadTCState m => Agda.TypeChecking.Monad.Base.MonadTCState (Agda.TypeChecking.Names.NamesT m)
instance Agda.TypeChecking.Monad.Base.MonadTCEnv m => Agda.TypeChecking.Monad.Base.MonadTCEnv (Agda.TypeChecking.Names.NamesT m)
instance Agda.TypeChecking.Monad.Debug.MonadDebug m => Agda.TypeChecking.Monad.Debug.MonadDebug (Agda.TypeChecking.Names.NamesT m)
instance Agda.Interaction.Options.HasOptions.HasOptions m => Agda.Interaction.Options.HasOptions.HasOptions (Agda.TypeChecking.Names.NamesT m)
instance Control.Monad.IO.Class.MonadIO m => Control.Monad.IO.Class.MonadIO (Agda.TypeChecking.Names.NamesT m)
instance Control.Monad.State.Class.MonadState s m => Control.Monad.State.Class.MonadState s (Agda.TypeChecking.Names.NamesT m)
instance Control.Monad.Trans.Class.MonadTrans Agda.TypeChecking.Names.NamesT
instance Control.Monad.Fail.MonadFail m => Control.Monad.Fail.MonadFail (Agda.TypeChecking.Names.NamesT m)
instance GHC.Base.Monad m => GHC.Base.Monad (Agda.TypeChecking.Names.NamesT m)
instance GHC.Base.Applicative m => GHC.Base.Applicative (Agda.TypeChecking.Names.NamesT m)
instance GHC.Base.Functor m => GHC.Base.Functor (Agda.TypeChecking.Names.NamesT m)
instance Data.Traversable.Traversable Agda.TypeChecking.Names.AbsN
instance Data.Foldable.Foldable Agda.TypeChecking.Names.AbsN
instance GHC.Base.Functor Agda.TypeChecking.Names.AbsN
instance Agda.TypeChecking.Substitute.Class.Subst a => Agda.TypeChecking.Substitute.Class.Subst (Agda.TypeChecking.Names.AbsN a)
instance Agda.TypeChecking.Monad.Builtin.HasBuiltins m => Agda.TypeChecking.Monad.Builtin.HasBuiltins (Agda.TypeChecking.Names.NamesT m)

module Agda.TypeChecking.Primitive.Base
(-->) :: Applicative m => m Type -> m Type -> m Type
infixr 4 -->
(.-->) :: Applicative m => m Type -> m Type -> m Type
infixr 4 .-->
(..-->) :: Applicative m => m Type -> m Type -> m Type
infixr 4 ..-->
garr :: Applicative m => (Relevance -> Relevance) -> m Type -> m Type -> m Type
gpi :: (MonadAddContext m, MonadDebug m) => ArgInfo -> String -> m Type -> m Type -> m Type
hPi :: (MonadAddContext m, MonadDebug m) => String -> m Type -> m Type -> m Type
nPi :: (MonadAddContext m, MonadDebug m) => String -> m Type -> m Type -> m Type
hPi' :: (MonadFail m, MonadAddContext m, MonadDebug m) => String -> NamesT m Type -> (NamesT m Term -> NamesT m Type) -> NamesT m Type
nPi' :: (MonadFail m, MonadAddContext m, MonadDebug m) => String -> NamesT m Type -> (NamesT m Term -> NamesT m Type) -> NamesT m Type
pPi' :: (MonadAddContext m, HasBuiltins m, MonadDebug m) => String -> NamesT m Term -> (NamesT m Term -> NamesT m Type) -> NamesT m Type

-- | Turn a <a>Pi</a> type into one whose domain is annotated finite, i.e.,
--   one that represents a <tt>Partial</tt> element rather than an actual
--   function.
toFinitePi :: Type -> Type
el' :: Applicative m => m Term -> m Term -> m Type
els :: Applicative m => m Sort -> m Term -> m Type
el's :: Applicative m => m Term -> m Term -> m Type
elInf :: Functor m => m Term -> m Type
elSSet :: Functor m => m Term -> m Type
nolam :: Term -> Term
varM :: Applicative m => Int -> m Term
gApply :: Applicative m => Hiding -> m Term -> m Term -> m Term
gApply' :: Applicative m => ArgInfo -> m Term -> m Term -> m Term
(<@>) :: Applicative m => m Term -> m Term -> m Term
infixl 9 <@>
(<#>) :: Applicative m => m Term -> m Term -> m Term
infixl 9 <#>
(<..>) :: Applicative m => m Term -> m Term -> m Term
(<@@>) :: Applicative m => m Term -> (m Term, m Term, m Term) -> m Term
list :: TCM Term -> TCM Term
tMaybe :: TCM Term -> TCM Term
io :: TCM Term -> TCM Term
path :: TCM Term -> TCM Term
el :: Functor m => m Term -> m Type

-- | The universe <tt>Set0</tt> as a type.
tset :: Applicative m => m Type

-- | <tt>SizeUniv</tt> as a sort.
sSizeUniv :: Sort

-- | <tt>SizeUniv</tt> as a type.
tSizeUniv :: Applicative m => m Type
tLevelUniv :: Applicative m => m Type

-- | Abbreviation: <tt>argN = <a>Arg</a> <a>defaultArgInfo</a></tt>.
argN :: e -> Arg e
domN :: e -> Dom e

-- | Abbreviation: <tt>argH = <a>hide</a> <a>Arg</a>
--   <a>defaultArgInfo</a></tt>.
argH :: e -> Arg e
domH :: e -> Dom e
lookupPrimitiveFunction :: PrimitiveId -> TCM PrimitiveImpl
lookupPrimitiveFunctionQ :: QName -> TCM (PrimitiveId, PrimitiveImpl)
getBuiltinName :: (HasBuiltins m, MonadReduce m) => BuiltinId -> m (Maybe QName)

-- | Convert a name in <a>Term</a> form back to <a>QName</a>.
getQNameFromTerm :: MonadReduce m => Term -> MaybeT m QName
isBuiltin :: (HasBuiltins m, MonadReduce m) => QName -> BuiltinId -> m Bool
data SigmaKit
SigmaKit :: QName -> ConHead -> QName -> QName -> SigmaKit
[sigmaName] :: SigmaKit -> QName
[sigmaCon] :: SigmaKit -> ConHead
[sigmaFst] :: SigmaKit -> QName
[sigmaSnd] :: SigmaKit -> QName
getSigmaKit :: (HasBuiltins m, HasConstInfo m) => m (Maybe SigmaKit)
instance GHC.Show.Show Agda.TypeChecking.Primitive.Base.SigmaKit
instance GHC.Classes.Eq Agda.TypeChecking.Primitive.Base.SigmaKit

module Agda.TypeChecking.Quote

-- | Parse <tt>quote</tt>.
quotedName :: (MonadTCError m, MonadAbsToCon m) => Expr -> m QName
data QuotingKit
QuotingKit :: (Term -> ReduceM Term) -> (Type -> ReduceM Term) -> (Dom Type -> ReduceM Term) -> (Definition -> ReduceM Term) -> (forall a. (a -> ReduceM Term) -> [a] -> ReduceM Term) -> QuotingKit
[quoteTermWithKit] :: QuotingKit -> Term -> ReduceM Term
[quoteTypeWithKit] :: QuotingKit -> Type -> ReduceM Term
[quoteDomWithKit] :: QuotingKit -> Dom Type -> ReduceM Term
[quoteDefnWithKit] :: QuotingKit -> Definition -> ReduceM Term
[quoteListWithKit] :: QuotingKit -> forall a. (a -> ReduceM Term) -> [a] -> ReduceM Term
quotingKit :: TCM QuotingKit
quoteString :: String -> Term
quoteName :: QName -> Term
quoteNat :: Integer -> Term
quoteConName :: ConHead -> Term
quoteMeta :: TopLevelModuleName -> MetaId -> Term
quoteTerm :: Term -> TCM Term
quoteType :: Type -> TCM Term
quoteDom :: Dom Type -> TCM Term
quoteDefn :: Definition -> TCM Term
quoteList :: [Term] -> TCM Term


-- | Implementations of the basic primitives of Cubical Agda: The interval
--   and its operations.
module Agda.TypeChecking.Primitive.Cubical.Base

-- | Checks that the correct variant of Cubical Agda is activated. Note
--   that <tt>--erased-cubical</tt> "counts as" <tt>--cubical</tt> in
--   erased contexts.
requireCubical :: Cubical -> String -> TCM ()

-- | Our good friend the interval type.
primIntervalType :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Type

-- | Implements both the <tt>min</tt> connection <i>and</i> conjunction on
--   the cofibration classifier.
primIMin' :: TCM PrimitiveImpl

-- | Implements both the <tt>max</tt> connection <i>and</i> disjunction on
--   the cofibration classifier.
primIMax' :: TCM PrimitiveImpl

-- | <tt>primDepIMin</tt> expresses that cofibrations are closed under
--   <tt>Σ</tt>. Thus, it serves as a dependent version of <a>primIMin</a>
--   (which, recall, implements <tt>_∧_</tt>). This is required for the
--   construction of the Kan operations in <tt>Id</tt>.
primDepIMin' :: TCM PrimitiveImpl

-- | Negation on the interval. Negation satisfies De Morgan's laws, and
--   their implementation is handled here.
primINeg' :: TCM PrimitiveImpl

-- | A helper for evaluating <tt>max</tt> on the interval in TCM&amp;co.
imax :: HasBuiltins m => m Term -> m Term -> m Term

-- | A helper for evaluating <tt>min</tt> on the interval in TCM&amp;co.
imin :: HasBuiltins m => m Term -> m Term -> m Term

-- | A helper for evaluating <tt>neg</tt> on the interval in TCM&amp;co.
ineg :: HasBuiltins m => m Term -> m Term
data Command
DoTransp :: Command
DoHComp :: Command

-- | Our Kan operations are <tt>transp</tt> and <tt>hcomp</tt>. The
--   KanOperation record stores the data associated with a Kan operation on
--   arbitrary types: A cofibration and an element of that type.
data KanOperation

-- | A transport problem consists of a cofibration, marking where the
--   transport is constant, and a term to move from the fibre over i0 to
--   the fibre over i1.
TranspOp :: Blocked (Arg Term) -> Arg Term -> KanOperation

-- | When this cofibration holds, the transport must definitionally be the
--   identity. This is handled generically by <tt>primTransHComp</tt> but
--   specific Kan operations may still need it.
[kanOpCofib] :: KanOperation -> Blocked (Arg Term)

-- | This is the term in <tt>A i0</tt> which we are transporting.
[kanOpBase] :: KanOperation -> Arg Term

-- | A composition problem consists of a partial element and a base.
--   Semantically, this is justified by the types being Kan fibrations,
--   i.e., having the lifting property against trivial cofibrations. While
--   the specified cofibration may not be trivial, (φ ∨ ~ r) for r ∉ φ is
--   *always* a trivial cofibration.
HCompOp :: Blocked (Arg Term) -> Arg Term -> Arg Term -> KanOperation

-- | When this cofibration holds, the transport must definitionally be the
--   identity. This is handled generically by <tt>primTransHComp</tt> but
--   specific Kan operations may still need it.
[kanOpCofib] :: KanOperation -> Blocked (Arg Term)

-- | The partial element itself
[kanOpSides] :: KanOperation -> Arg Term

-- | This is the term in <tt>A i0</tt> which we are transporting.
[kanOpBase] :: KanOperation -> Arg Term

-- | The built-in name associated with a particular Kan operation.
kanOpName :: KanOperation -> String

-- | For the Kan operations in <tt>Glue</tt> and <tt>hcomp {Type}</tt>, we
--   optimise evaluation a tiny bit by differentiating the term produced
--   when evaluating a Kan operation by itself vs evaluating it under
--   <tt>unglue</tt>. (See <tt>headStop</tt> below.)
data TermPosition
Head :: TermPosition
Eliminated :: TermPosition

-- | Kan operations for the "unstable" type formers (<tt>Glue</tt>,
--   <tt>hcomp {Type}</tt>) are computed "negatively": they never actually
--   produce a <tt>glue φ t a</tt> term. Instead, we block the computation
--   unless such a term would reduce further, which happens in two cases:
--   
--   <ul>
--   <li>when the formula <tt>φ</tt> is i1, in which case we reduce to
--   <tt>t</tt>;</li>
--   <li>when we're under an <tt>unglue</tt>, i.e. in <a>Eliminated</a>
--   <a>TermPosition</a>, in which case we reduce to <tt>a</tt>.</li>
--   </ul>
headStop :: PureTCM m => TermPosition -> m Term -> m Bool

-- | Are we looking at a family of things, or at a single thing?
data FamilyOrNot a
IsFam :: a -> FamilyOrNot a
[famThing] :: FamilyOrNot a -> a
IsNot :: a -> FamilyOrNot a
[famThing] :: FamilyOrNot a -> a
familyOrNot :: IsString p => FamilyOrNot a -> p

-- | Build a partial element. The type of the resulting partial element can
--   depend on the computed extent, which we denote by <tt>φ</tt> here.
--   Note that <tt>φ</tt> is the n-ary disjunction of all the <tt>ψ</tt>s.
combineSys :: HasBuiltins m => NamesT m Term -> NamesT m Term -> [(NamesT m Term, NamesT m Term)] -> NamesT m Term

-- | Build a partial element, and compute its extent. See <a>combineSys</a>
--   for the details.
combineSys' :: forall m. HasBuiltins m => NamesT m Term -> NamesT m Term -> [(NamesT m Term, NamesT m Term)] -> NamesT m (Term, Term)

-- | Helper function for constructing the type of fibres of a function over
--   a given point.
fiber :: (HasBuiltins m, HasConstInfo m) => NamesT m Term -> NamesT m Term -> NamesT m Term -> NamesT m Term -> NamesT m Term -> NamesT m Term -> NamesT m Term

-- | Helper function for constructing the filler of a given composition
--   problem.
hfill :: (HasBuiltins m, HasConstInfo m) => NamesT m Term -> NamesT m Term -> NamesT m Term -> NamesT m Term -> NamesT m Term -> NamesT m Term -> NamesT m Term

-- | Decompose an interval expression <tt>φ : I</tt> into a set of possible
--   assignments for the variables mentioned in <tt>φ</tt>, together any
--   leftover neutral terms that could not be put into <a>IntervalView</a>
--   form.
decomposeInterval' :: HasBuiltins m => Term -> m [(IntMap BoolSet, [Term])]

-- | Decompose an interval expression <tt>i : I</tt> as in
--   <a>decomposeInterval'</a>, but discard any inconsistent mappings.
decomposeInterval :: HasBuiltins m => Term -> m [(IntMap Bool, [Term])]
reduce2Lam :: Term -> ReduceM (Blocked Term)

-- | Are we looking at an application of the <tt>Sub</tt> type? If so,
--   return: * The type we're an extension of * The extent * The partial
--   element.
isCubicalSubtype :: PureTCM m => Type -> m (Maybe (Term, Term, Term, Term))
instance GHC.Show.Show Agda.TypeChecking.Primitive.Cubical.Base.Command
instance GHC.Classes.Eq Agda.TypeChecking.Primitive.Cubical.Base.Command
instance Data.Traversable.Traversable Agda.TypeChecking.Primitive.Cubical.Base.FamilyOrNot
instance Data.Foldable.Foldable Agda.TypeChecking.Primitive.Cubical.Base.FamilyOrNot
instance GHC.Base.Functor Agda.TypeChecking.Primitive.Cubical.Base.FamilyOrNot
instance GHC.Show.Show a => GHC.Show.Show (Agda.TypeChecking.Primitive.Cubical.Base.FamilyOrNot a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.TypeChecking.Primitive.Cubical.Base.FamilyOrNot a)
instance GHC.Show.Show Agda.TypeChecking.Primitive.Cubical.Base.TermPosition
instance GHC.Classes.Eq Agda.TypeChecking.Primitive.Cubical.Base.TermPosition
instance Agda.TypeChecking.Reduce.Reduce a => Agda.TypeChecking.Reduce.Reduce (Agda.TypeChecking.Primitive.Cubical.Base.FamilyOrNot a)


-- | Implementation of the primitives relating to Cubical identity types.
module Agda.TypeChecking.Primitive.Cubical.Id

-- | Primitive elimination rule for the cubical identity types. Unlike J,
--   <tt>idElim</tt> makes explicit the structure of Swan's identity types
--   as being pairs of a cofibration and a path. Moreover, it records that
--   the path is definitionally <tt>refl</tt> under that cofibration.
primIdElim' :: TCM PrimitiveImpl

-- | Introduction form for the cubical identity types.
primConId' :: TCM PrimitiveImpl

-- | Extract the underlying cofibration from an inhabitant of the cubical
--   identity types.
--   
--   TODO (Amy, 2022-08-17): Projecting a cofibration from a Kan type
--   violates the cubical phase distinction.
primIdFace' :: TCM PrimitiveImpl

-- | Extract the underlying path from an inhabitant of the cubical identity
--   types.
primIdPath' :: TCM PrimitiveImpl
doIdKanOp :: KanOperation -> FamilyOrNot (Arg Term) -> FamilyOrNot (Arg Term, Arg Term, Arg Term) -> ReduceM (Maybe (Reduced t Term))

module Agda.TypeChecking.Primitive.Cubical.Glue

-- | Define a "ghcomp" version of gcomp. Normal comp looks like:
--   
--   comp^i A [ phi -&gt; u ] u0 = hcomp^i A(1/i) [ phi -&gt; forward A i u
--   ] (forward A 0 u0)
--   
--   So for "gcomp" we compute:
--   
--   gcomp^i A [ phi -&gt; u ] u0 = hcomp^i A(1/i) [ phi -&gt; forward A i
--   u, ~ phi -&gt; forward A 0 u0 ] (forward A 0 u0)
--   
--   The point of this is that gcomp does not produce any empty systems (if
--   phi = 0 it will reduce to "forward A 0 u".
mkGComp :: forall m. HasBuiltins m => String -> NamesT m (NamesT m Term -> NamesT m Term -> NamesT m Term -> NamesT m Term -> NamesT m Term -> NamesT m Term)

-- | Perform the Kan operations for a <tt>Glue φ A (T , e)</tt> type.
doGlueKanOp :: forall m. PureTCM m => KanOperation -> FamilyOrNot (Arg Term, Arg Term, Arg Term, Arg Term, Arg Term, Arg Term) -> TermPosition -> m (Maybe Term)
primGlue' :: TCM PrimitiveImpl

-- | The implementation of <a>prim_glue</a>, the introduction form for
--   <tt>Glue</tt> types.
prim_glue' :: TCM PrimitiveImpl

-- | The implementation of <a>prim_unglue</a>, the elimination form for
--   <tt>Glue</tt> types.
prim_unglue' :: TCM PrimitiveImpl

module Agda.TypeChecking.Primitive.Cubical.HCompU

-- | Perform the Kan operations for an <tt>hcomp {A = Type} {φ} u u0</tt>
--   type.
doHCompUKanOp :: forall m. PureTCM m => KanOperation -> FamilyOrNot (Arg Term, Arg Term, Arg Term, Arg Term) -> TermPosition -> m (Maybe Term)

-- | The implementation of <a>prim_glueU</a>, the introduction form for
--   <tt>hcomp</tt> types.
prim_glueU' :: TCM PrimitiveImpl

-- | The implementation of <a>prim_unglueU</a>, the elimination form for
--   <tt>hcomp</tt> types.
prim_unglueU' :: TCM PrimitiveImpl

module Agda.TypeChecking.Primitive.Cubical
type LM m a = NamesT (ExceptT (Closure (Abs Type)) m) a
data TranspError
CannotTransp :: Closure (Abs Type) -> TranspError
[errorType] :: TranspError -> Closure (Abs Type)

-- | A <tt>Type</tt> with sort <tt>Type l</tt> Such a type supports both
--   hcomp and transp.
data LType
LEl :: Level -> Term -> LType

-- | A <tt>Type</tt> that either has sort <tt>Type l</tt> or is a closed
--   definition. Such a type supports some version of transp. In particular
--   we want to allow the Interval as a <tt>ClosedType</tt>.
data CType
ClosedType :: Sort -> QName -> CType
LType :: LType -> CType
primPOr :: TCM PrimitiveImpl

-- | CCHM <a>primComp</a> is implemented in terms of <a>hcomp</a> and
--   <tt>transport</tt>. The definition of it comes from <a>mkComp</a>.
primComp :: TCM PrimitiveImpl
primTransHComp :: Command -> [Arg Term] -> Int -> ReduceM (Reduced MaybeReducedArgs Term)
primPartial' :: TCM PrimitiveImpl
primPartialP' :: TCM PrimitiveImpl
primSubOut' :: TCM PrimitiveImpl
primTrans' :: TCM PrimitiveImpl
primHComp' :: TCM PrimitiveImpl

-- | Construct a helper for CCHM composition, with a string indicating what
--   function uses it.
mkComp :: forall m. HasBuiltins m => String -> NamesT m (NamesT m Term -> NamesT m Term -> NamesT m Term -> NamesT m Term -> NamesT m Term -> NamesT m Term)

-- | Construct an application of buitlinComp. Use instead of <a>mkComp</a>
--   if reducing directly to hcomp + transport would be problematic.
mkCompLazy :: HasBuiltins m => String -> NamesT m (NamesT m Term -> NamesT m Term -> NamesT m Term -> NamesT m Term -> NamesT m Term -> NamesT m Term)

-- | Implementation of Kan operations for Pi types. The implementation of
--   <tt>transp</tt> and <tt>hcomp</tt> for Pi types has many
--   commonalities, so most of it is shared between the two cases.
doPiKanOp :: KanOperation -> ArgName -> FamilyOrNot (Dom Type, Abs Type) -> ReduceM (Maybe Term)

-- | Compute Kan operations in a type of dependent paths.
doPathPKanOp :: KanOperation -> FamilyOrNot (Arg Term) -> FamilyOrNot (Arg Term, Arg Term, Arg Term) -> ReduceM (Reduced MaybeReducedArgs Term)
redReturnNoSimpl :: a -> ReduceM (Reduced a' a)
hcomp :: (HasBuiltins m, MonadError TCErr m, MonadReduce m, MonadPretty m) => NamesT m Type -> [(NamesT m Term, NamesT m Term)] -> NamesT m Term -> NamesT m Term
primFaceForall' :: TCM PrimitiveImpl

-- | Tries to <tt>primTransp</tt> a whole telescope of arguments, following
--   the rule for Σ types. If a type in the telescope does not support
--   transp, <tt>transpTel</tt> throws it as an exception.
transpTel :: Abs Telescope -> Term -> Args -> ExceptT (Closure (Abs Type)) TCM Args
transpTel' :: (PureTCM m, MonadError TCErr m) => Bool -> Abs Telescope -> Term -> Args -> ExceptT (Closure (Abs Type)) m Args
transpSysTel' :: forall m. (PureTCM m, MonadError TCErr m) => Bool -> Abs Telescope -> [(Term, Abs [Term])] -> Term -> Args -> ExceptT (Closure (Abs Type)) m Args
trFillTel' :: (PureTCM m, MonadError TCErr m) => Bool -> Abs Telescope -> Term -> Args -> Term -> ExceptT (Closure (Abs Type)) m Args

-- | Like <tt>transpTel</tt> but performing a transpFill.
trFillTel :: Abs Telescope -> Term -> Args -> Term -> ExceptT (Closure (Abs Type)) TCM Args
pathTelescope :: forall m. (PureTCM m, MonadError TCErr m) => Telescope -> [Arg Term] -> [Arg Term] -> m Telescope
pathTelescope' :: forall m. (PureTCM m, MonadError (Closure Type) m) => Telescope -> [Arg Term] -> [Arg Term] -> m Telescope
tryTranspError :: TCM a -> TCM (Either (Closure (Abs Type)) a)
transpPathPTel' :: NamesT TCM (Abs (Abs Telescope)) -> [NamesT TCM Term] -> [NamesT TCM Term] -> NamesT TCM Term -> [NamesT TCM Term] -> NamesT TCM [Arg Term]
transpPathTel' :: NamesT TCM (Abs Telescope) -> [NamesT TCM Term] -> [NamesT TCM Term] -> NamesT TCM Term -> [NamesT TCM Term] -> NamesT TCM [Arg Term]
trFillPathTel' :: NamesT TCM (Abs Telescope) -> [NamesT TCM Term] -> [NamesT TCM Term] -> NamesT TCM Term -> [NamesT TCM Term] -> NamesT TCM Term -> NamesT TCM [Arg Term]
trFillPathPTel' :: NamesT TCM (Abs (Abs Telescope)) -> [NamesT TCM Term] -> [NamesT TCM Term] -> NamesT TCM Term -> [NamesT TCM Term] -> NamesT TCM Term -> NamesT TCM [Arg Term]
expTelescope :: Type -> Telescope -> Telescope

-- | Γ, Δ^I, i : I |- expS |Δ| : Γ, Δ
expS :: Nat -> Substitution
fromLType :: LType -> Type
lTypeLevel :: LType -> Level
toLType :: MonadReduce m => Type -> m (Maybe LType)
fromCType :: CType -> Type
toCType :: MonadReduce m => Type -> m (Maybe CType)
transpSys :: (HasBuiltins m, MonadError TCErr m, MonadReduce m) => NamesT m (Abs Type) -> [(NamesT m Term, NamesT m Term)] -> NamesT m Term -> NamesT m Term -> NamesT m Term
debugClause :: String -> Clause -> TCM ()
instance GHC.Show.Show Agda.TypeChecking.Primitive.Cubical.LType
instance GHC.Classes.Eq Agda.TypeChecking.Primitive.Cubical.LType
instance GHC.Show.Show Agda.TypeChecking.Primitive.Cubical.CType
instance GHC.Classes.Eq Agda.TypeChecking.Primitive.Cubical.CType
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Primitive.Cubical.CType
instance Agda.TypeChecking.Substitute.Class.Subst Agda.TypeChecking.Primitive.Cubical.CType
instance Agda.TypeChecking.Substitute.Class.Subst Agda.TypeChecking.Primitive.Cubical.LType
instance GHC.Exception.Type.Exception Agda.TypeChecking.Primitive.Cubical.TranspError
instance GHC.Show.Show Agda.TypeChecking.Primitive.Cubical.TranspError


-- | Primitive functions, such as addition on builtin integers.
module Agda.TypeChecking.Primitive
type Fun a = a -> a
type Pred a = a -> Bool
newtype Nat
Nat :: Integer -> Nat
[unNat] :: Nat -> Integer
type Op a = a -> a -> a
newtype Lvl
Lvl :: Integer -> Lvl
[unLvl] :: Lvl -> Integer
class PrimType a
primType :: PrimType a => a -> TCM Type
primType :: (PrimType a, PrimTerm a) => a -> TCM Type
class PrimType a => PrimTerm a
primTerm :: PrimTerm a => a -> TCM Term
class ToTerm a
toTerm :: ToTerm a => TCM (a -> Term)
toTermR :: ToTerm a => TCM (a -> ReduceM Term)
type FromTermFunction a = Arg Term -> ReduceM (Reduced (MaybeReduced (Arg Term)) a)
class FromTerm a
fromTerm :: FromTerm a => TCM (FromTermFunction a)
type Rel a = a -> a -> Bool
getRefl :: TCM (Arg Term -> Term)
primitiveFunctions :: Map PrimitiveId (TCM PrimitiveImpl)
primWord64ToNatInjective :: TCM PrimitiveImpl
primFloatToWord64Injective :: TCM PrimitiveImpl
primCharToNatInjective :: TCM PrimitiveImpl
primStringToListInjective :: TCM PrimitiveImpl
primStringFromListInjective :: TCM PrimitiveImpl

-- | <pre>
--   primEraseEquality : {a : Level} {A : Set a} {x y : A} -&gt; x ≡ y -&gt; x ≡ y
--   </pre>
primEraseEquality :: TCM PrimitiveImpl
primForce :: TCM PrimitiveImpl
primForceLemma :: TCM PrimitiveImpl
primQNameToWord64sInjective :: TCM PrimitiveImpl
primMetaToNatInjective :: TCM PrimitiveImpl

-- | <tt>buildList A ts</tt> builds a list of type <tt>List A</tt>. Assumes
--   that the terms <tt>ts</tt> all have type <tt>A</tt>.
buildList :: TCM ([Term] -> Term)
fromLiteral :: (Literal -> Maybe a) -> TCM (FromTermFunction a)
fromReducedTerm :: (Term -> Maybe a) -> TCM (FromTermFunction a)

-- | <tt>mkPrimInjective</tt> takes two Set0 <tt>a</tt> and <tt>b</tt> and
--   a function <tt>f</tt> of type <tt>a -&gt; b</tt> and outputs a
--   primitive internalizing the fact that <tt>f</tt> is injective.
mkPrimInjective :: Type -> Type -> QName -> TCM PrimitiveImpl

-- | Converts <a>MetaId</a>s to natural numbers.
metaToNat :: MetaId -> Nat

-- | Get the <a>ArgInfo</a> of the principal argument of BUILTIN REFL.
--   
--   Returns <tt>Nothing</tt> for e.g. <tt> data Eq {a} {A : Set a} (x : A)
--   : A → Set a where refl : Eq x x </tt>
--   
--   Returns <tt>Just ...</tt> for e.g. <tt> data Eq {a} {A : Set a} : (x y
--   : A) → Set a where refl : ∀ x → Eq x x </tt>
getReflArgInfo :: ConHead -> TCM (Maybe ArgInfo)

-- | Used for both <tt>primForce</tt> and <tt>primForceLemma</tt>.
genPrimForce :: TCM Type -> (Term -> Arg Term -> Term) -> TCM PrimitiveImpl
mkPrimLevelZero :: TCM PrimitiveImpl
mkPrimLevelSuc :: TCM PrimitiveImpl
mkPrimLevelMax :: TCM PrimitiveImpl
primLockUniv' :: TCM PrimitiveImpl
mkPrimFun1TCM :: (FromTerm a, ToTerm b) => TCM Type -> (a -> ReduceM b) -> TCM PrimitiveImpl
mkPrimFun1 :: (PrimType a, FromTerm a, PrimType b, ToTerm b) => (a -> b) -> TCM PrimitiveImpl
mkPrimFun2 :: (PrimType a, FromTerm a, ToTerm a, PrimType b, FromTerm b, PrimType c, ToTerm c) => (a -> b -> c) -> TCM PrimitiveImpl
mkPrimFun3 :: (PrimType a, FromTerm a, ToTerm a, PrimType b, FromTerm b, ToTerm b, PrimType c, FromTerm c, PrimType d, ToTerm d) => (a -> b -> c -> d) -> TCM PrimitiveImpl
mkPrimFun4 :: (PrimType a, FromTerm a, ToTerm a, PrimType b, FromTerm b, ToTerm b, PrimType c, FromTerm c, ToTerm c, PrimType d, FromTerm d, PrimType e, ToTerm e) => (a -> b -> c -> d -> e) -> TCM PrimitiveImpl
instance GHC.Real.Real Agda.TypeChecking.Primitive.Nat
instance GHC.Enum.Enum Agda.TypeChecking.Primitive.Nat
instance GHC.Num.Num Agda.TypeChecking.Primitive.Nat
instance GHC.Classes.Ord Agda.TypeChecking.Primitive.Nat
instance GHC.Classes.Eq Agda.TypeChecking.Primitive.Nat
instance GHC.Classes.Ord Agda.TypeChecking.Primitive.Lvl
instance GHC.Classes.Eq Agda.TypeChecking.Primitive.Lvl
instance Agda.TypeChecking.Primitive.FromTerm GHC.Num.Integer.Integer
instance Agda.TypeChecking.Primitive.FromTerm Agda.TypeChecking.Primitive.Nat
instance Agda.TypeChecking.Primitive.FromTerm GHC.Word.Word64
instance Agda.TypeChecking.Primitive.FromTerm Agda.TypeChecking.Primitive.Lvl
instance Agda.TypeChecking.Primitive.FromTerm GHC.Types.Double
instance Agda.TypeChecking.Primitive.FromTerm GHC.Types.Char
instance Agda.TypeChecking.Primitive.FromTerm Data.Text.Internal.Text
instance Agda.TypeChecking.Primitive.FromTerm Agda.Syntax.Abstract.Name.QName
instance Agda.TypeChecking.Primitive.FromTerm Agda.Syntax.Common.MetaId
instance Agda.TypeChecking.Primitive.FromTerm GHC.Types.Bool
instance (Agda.TypeChecking.Primitive.ToTerm a, Agda.TypeChecking.Primitive.FromTerm a) => Agda.TypeChecking.Primitive.FromTerm [a]
instance Agda.TypeChecking.Primitive.FromTerm a => Agda.TypeChecking.Primitive.FromTerm (GHC.Maybe.Maybe a)
instance Agda.TypeChecking.Primitive.ToTerm Agda.TypeChecking.Primitive.Nat
instance Agda.TypeChecking.Primitive.ToTerm GHC.Word.Word64
instance Agda.TypeChecking.Primitive.ToTerm Agda.TypeChecking.Primitive.Lvl
instance Agda.TypeChecking.Primitive.ToTerm GHC.Types.Double
instance Agda.TypeChecking.Primitive.ToTerm GHC.Types.Char
instance Agda.TypeChecking.Primitive.ToTerm Data.Text.Internal.Text
instance Agda.TypeChecking.Primitive.ToTerm Agda.Syntax.Abstract.Name.QName
instance Agda.TypeChecking.Primitive.ToTerm Agda.Syntax.Common.MetaId
instance Agda.TypeChecking.Primitive.ToTerm GHC.Num.Integer.Integer
instance Agda.TypeChecking.Primitive.ToTerm GHC.Types.Bool
instance Agda.TypeChecking.Primitive.ToTerm Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Primitive.ToTerm (Agda.Syntax.Internal.Dom Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.Primitive.ToTerm Agda.Syntax.Internal.Type
instance Agda.TypeChecking.Primitive.ToTerm Agda.Syntax.Common.ArgInfo
instance Agda.TypeChecking.Primitive.ToTerm Agda.Syntax.Common.Fixity'
instance Agda.TypeChecking.Primitive.ToTerm Agda.Syntax.Common.Fixity
instance Agda.TypeChecking.Primitive.ToTerm Agda.Syntax.Common.Associativity
instance Agda.TypeChecking.Primitive.ToTerm Agda.Syntax.Internal.Blockers.Blocker
instance Agda.TypeChecking.Primitive.ToTerm Agda.Syntax.Common.FixityLevel
instance (Agda.TypeChecking.Primitive.ToTerm a, Agda.TypeChecking.Primitive.ToTerm b) => Agda.TypeChecking.Primitive.ToTerm (a, b)
instance Agda.TypeChecking.Primitive.ToTerm a => Agda.TypeChecking.Primitive.ToTerm [a]
instance Agda.TypeChecking.Primitive.ToTerm a => Agda.TypeChecking.Primitive.ToTerm (GHC.Maybe.Maybe a)
instance (Agda.TypeChecking.Primitive.PrimType a, Agda.TypeChecking.Primitive.PrimType b) => Agda.TypeChecking.Primitive.PrimType (a -> b)
instance (Agda.TypeChecking.Primitive.PrimType a, Agda.TypeChecking.Primitive.PrimType b) => Agda.TypeChecking.Primitive.PrimTerm (a -> b)
instance (Agda.TypeChecking.Primitive.PrimType a, Agda.TypeChecking.Primitive.PrimType b) => Agda.TypeChecking.Primitive.PrimType (a, b)
instance (Agda.TypeChecking.Primitive.PrimType a, Agda.TypeChecking.Primitive.PrimType b) => Agda.TypeChecking.Primitive.PrimTerm (a, b)
instance Agda.TypeChecking.Primitive.PrimType GHC.Num.Integer.Integer
instance Agda.TypeChecking.Primitive.PrimTerm GHC.Num.Integer.Integer
instance Agda.TypeChecking.Primitive.PrimType GHC.Word.Word64
instance Agda.TypeChecking.Primitive.PrimTerm GHC.Word.Word64
instance Agda.TypeChecking.Primitive.PrimType GHC.Types.Bool
instance Agda.TypeChecking.Primitive.PrimTerm GHC.Types.Bool
instance Agda.TypeChecking.Primitive.PrimType GHC.Types.Char
instance Agda.TypeChecking.Primitive.PrimTerm GHC.Types.Char
instance Agda.TypeChecking.Primitive.PrimType GHC.Types.Double
instance Agda.TypeChecking.Primitive.PrimTerm GHC.Types.Double
instance Agda.TypeChecking.Primitive.PrimType Data.Text.Internal.Text
instance Agda.TypeChecking.Primitive.PrimTerm Data.Text.Internal.Text
instance Agda.TypeChecking.Primitive.PrimType Agda.TypeChecking.Primitive.Nat
instance Agda.TypeChecking.Primitive.PrimTerm Agda.TypeChecking.Primitive.Nat
instance Agda.TypeChecking.Primitive.PrimType Agda.TypeChecking.Primitive.Lvl
instance Agda.TypeChecking.Primitive.PrimTerm Agda.TypeChecking.Primitive.Lvl
instance Agda.TypeChecking.Primitive.PrimType Agda.Syntax.Abstract.Name.QName
instance Agda.TypeChecking.Primitive.PrimTerm Agda.Syntax.Abstract.Name.QName
instance Agda.TypeChecking.Primitive.PrimType Agda.Syntax.Common.MetaId
instance Agda.TypeChecking.Primitive.PrimTerm Agda.Syntax.Common.MetaId
instance Agda.TypeChecking.Primitive.PrimType Agda.Syntax.Internal.Type
instance Agda.TypeChecking.Primitive.PrimTerm Agda.Syntax.Internal.Type
instance Agda.TypeChecking.Primitive.PrimType Agda.Syntax.Common.Fixity'
instance Agda.TypeChecking.Primitive.PrimTerm Agda.Syntax.Common.Fixity'
instance Agda.TypeChecking.Primitive.PrimTerm a => Agda.TypeChecking.Primitive.PrimType [a]
instance Agda.TypeChecking.Primitive.PrimTerm a => Agda.TypeChecking.Primitive.PrimTerm [a]
instance Agda.TypeChecking.Primitive.PrimTerm a => Agda.TypeChecking.Primitive.PrimType (GHC.Maybe.Maybe a)
instance Agda.TypeChecking.Primitive.PrimTerm a => Agda.TypeChecking.Primitive.PrimTerm (GHC.Maybe.Maybe a)
instance Agda.TypeChecking.Primitive.PrimTerm a => Agda.TypeChecking.Primitive.PrimType (GHC.Types.IO a)
instance Agda.TypeChecking.Primitive.PrimTerm a => Agda.TypeChecking.Primitive.PrimTerm (GHC.Types.IO a)
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Primitive.Lvl
instance GHC.Real.Integral Agda.TypeChecking.Primitive.Nat
instance Agda.Syntax.Internal.Generic.TermLike Agda.TypeChecking.Primitive.Nat
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Primitive.Nat


-- | Compile-time irrelevance.
--   
--   In type theory with compile-time irrelevance à la Pfenning (LiCS
--   2001), variables in the context are annotated with relevance
--   attributes. @<tt> Γ = r₁x₁:A₁, ..., rⱼxⱼ:Aⱼ </tt><tt> To handle
--   irrelevant projections, we also record the current relevance attribute
--   in the judgement. For instance, this attribute is equal to to
--   <a>Irrelevant</a> if we are in an irrelevant position, like an
--   irrelevant argument. </tt><tt> Γ ⊢r t : A </tt><tt> Only relevant
--   variables can be used: </tt>@
--   
--   (Relevant x : A) ∈ Γ -------------------- Γ ⊢r x : A @<tt> Irrelevant
--   global declarations can only be used if </tt>r = Irrelevant@.
--   
--   When we enter a <tt>r'</tt>-relevant function argument, we compose the
--   <tt>r</tt> with <tt>r'</tt> and (left-)divide the attributes in the
--   context by <tt>r'</tt>. @<tt> Γ ⊢r t : (r' x : A) → B r' Γ ⊢(r'·r) u :
--   A --------------------------------------------------------- Γ ⊢r t u :
--   B[u/x] </tt><tt> No surprises for abstraction: </tt>@
--   
--   Γ, (r' x : A) ⊢r : B ----------------------------- Γ ⊢r λxt : (r' x :
--   A) → B @@
--   
--   This is different for runtime irrelevance (erasure) which is
--   `<tt>flat'</tt>, meaning that once one is in an irrelevant context,
--   all new assumptions will be usable, since they are turned relevant
--   once entering the context. See Conor McBride (WadlerFest 2016), for a
--   type system in this spirit:
--   
--   We use such a rule for runtime-irrelevance: @<tt> Γ, (q q') x : A ⊢q t
--   : B ------------------------------ Γ ⊢q λxt : (q' x : A) → B </tt>@
--   
--   Conor's system is however set up differently, with a very different
--   variable rule:
--   
--   @@
--   
--   (q x : A) ∈ Γ -------------- Γ ⊢q x : A
--   
--   Γ, (q·p) x : A ⊢q t : B ----------------------------- Γ ⊢q λxt : (p x
--   : A) → B
--   
--   Γ ⊢q t : (p x : A) → B Γ' ⊢qp u : A
--   ------------------------------------------------- Γ + Γ' ⊢q t u :
--   B[u/x] @@
module Agda.TypeChecking.Irrelevance

-- | Check whether something can be used in a position of the given
--   relevance.
--   
--   This is a substitute for double-checking that only makes sure
--   relevances are correct. See issue #2640.
--   
--   Used in unifier (<tt> unifyStep Solution{}</tt>).
--   
--   At the moment, this implements McBride-style irrelevance, where
--   Pfenning-style would be the most accurate thing. However, these two
--   notions only differ how they handle bound variables in a term. Here,
--   we are only concerned in the free variables, used meta-variables, and
--   used (irrelevant) definitions.
class UsableRelevance a
usableRel :: (UsableRelevance a, ReadTCState m, HasConstInfo m, MonadTCEnv m, MonadAddContext m, MonadDebug m) => Relevance -> a -> m Bool

-- | Check whether something can be used in a position of the given
--   modality.
--   
--   This is a substitute for double-checking that only makes sure
--   modalities are correct. See issue #2640.
--   
--   Used in unifier (<tt> unifyStep Solution{}</tt>).
--   
--   This uses McBride-style modality checking. It does not differ from
--   Pfenning-style if we are only interested in the modality of the free
--   variables, used meta-variables, and used definitions.
class UsableModality a
usableMod :: (UsableModality a, ReadTCState m, HasConstInfo m, MonadTCEnv m, MonadAddContext m, MonadDebug m, MonadReduce m, MonadError Blocker m) => Modality -> a -> m Bool
usableModAbs :: (Subst a, MonadAddContext m, UsableModality a, ReadTCState m, HasConstInfo m, MonadReduce m, MonadError Blocker m) => ArgInfo -> Modality -> Abs a -> m Bool
usableAtModality' :: MonadConstraint TCM => Maybe Sort -> WhyCheckModality -> Modality -> Term -> TCM ()
usableAtModality :: MonadConstraint TCM => WhyCheckModality -> Modality -> Term -> TCM ()

-- | Is a type a proposition? (Needs reduction.)
isPropM :: (LensSort a, PrettyTCM a, PureTCM m, MonadBlock m) => a -> m Bool
isIrrelevantOrPropM :: (LensRelevance a, LensSort a, PrettyTCM a, PureTCM m, MonadBlock m) => a -> m Bool
allIrrelevantOrPropTel :: (PureTCM m, MonadBlock m) => Telescope -> m Bool

-- | Is a type fibrant (i.e. Type, Prop)?
isFibrant :: (LensSort a, PureTCM m, MonadBlock m) => a -> m Bool

-- | Cofibrant types are those that could be the domain of a fibrant pi
--   type. (Notion by C. Sattler).
isCoFibrantSort :: (LensSort a, PureTCM m, MonadBlock m) => a -> m Bool
instance Agda.TypeChecking.Irrelevance.UsableModality Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Irrelevance.UsableRelevance a => Agda.TypeChecking.Irrelevance.UsableModality (Agda.Syntax.Internal.Type' a)
instance Agda.TypeChecking.Irrelevance.UsableModality Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Irrelevance.UsableModality Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Irrelevance.UsableModality a => Agda.TypeChecking.Irrelevance.UsableModality [a]
instance (Agda.TypeChecking.Irrelevance.UsableModality a, Agda.TypeChecking.Irrelevance.UsableModality b) => Agda.TypeChecking.Irrelevance.UsableModality (a, b)
instance Agda.TypeChecking.Irrelevance.UsableModality a => Agda.TypeChecking.Irrelevance.UsableModality (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.TypeChecking.Irrelevance.UsableModality a => Agda.TypeChecking.Irrelevance.UsableModality (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Irrelevance.UsableModality a => Agda.TypeChecking.Irrelevance.UsableModality (Agda.Syntax.Internal.Dom a)
instance Agda.TypeChecking.Irrelevance.UsableRelevance Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Irrelevance.UsableRelevance a => Agda.TypeChecking.Irrelevance.UsableRelevance (Agda.Syntax.Internal.Type' a)
instance Agda.TypeChecking.Irrelevance.UsableRelevance Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Irrelevance.UsableRelevance Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Irrelevance.UsableRelevance Agda.Syntax.Internal.PlusLevel
instance Agda.TypeChecking.Irrelevance.UsableRelevance a => Agda.TypeChecking.Irrelevance.UsableRelevance [a]
instance (Agda.TypeChecking.Irrelevance.UsableRelevance a, Agda.TypeChecking.Irrelevance.UsableRelevance b) => Agda.TypeChecking.Irrelevance.UsableRelevance (a, b)
instance (Agda.TypeChecking.Irrelevance.UsableRelevance a, Agda.TypeChecking.Irrelevance.UsableRelevance b, Agda.TypeChecking.Irrelevance.UsableRelevance c) => Agda.TypeChecking.Irrelevance.UsableRelevance (a, b, c)
instance Agda.TypeChecking.Irrelevance.UsableRelevance a => Agda.TypeChecking.Irrelevance.UsableRelevance (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.TypeChecking.Irrelevance.UsableRelevance a => Agda.TypeChecking.Irrelevance.UsableRelevance (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Irrelevance.UsableRelevance a => Agda.TypeChecking.Irrelevance.UsableRelevance (Agda.Syntax.Internal.Dom a)
instance (Agda.TypeChecking.Substitute.Class.Subst a, Agda.TypeChecking.Irrelevance.UsableRelevance a) => Agda.TypeChecking.Irrelevance.UsableRelevance (Agda.Syntax.Internal.Abs a)

module Agda.TypeChecking.Records
mkCon :: ConHead -> ConInfo -> Args -> Term

-- | Order the fields of a record construction.
orderFields :: forall a. HasRange a => QName -> (Arg Name -> a) -> [Arg Name] -> [(Name, a)] -> Writer [RecordFieldWarning] [a]

-- | Raise generated <a>Warning</a>s as warnings.
warnOnRecordFieldWarnings :: Writer [RecordFieldWarning] a -> TCM a

-- | Raise generated <a>Warning</a>s as errors.
failOnRecordFieldWarnings :: Writer [RecordFieldWarning] a -> TCM a

-- | Order the fields of a record construction. Raise generated
--   <a>Warning</a>s as warnings.
orderFieldsWarn :: forall a. HasRange a => QName -> (Arg Name -> a) -> [Arg Name] -> [(Name, a)] -> TCM [a]

-- | Order the fields of a record construction. Raise generated
--   <a>Warning</a>s as errors.
orderFieldsFail :: forall a. HasRange a => QName -> (Arg Name -> a) -> [Arg Name] -> [(Name, a)] -> TCM [a]

-- | A record field assignment <tt>record{xs = es}</tt> might not mention
--   all visible fields. <tt>insertMissingFields</tt> inserts placeholders
--   for the missing visible fields and returns the values in order of the
--   fields in the record declaration.
insertMissingFields :: forall a. HasRange a => QName -> (Name -> a) -> [FieldAssignment' a] -> [Arg Name] -> Writer [RecordFieldWarning] [NamedArg a]

-- | A record field assignment <tt>record{xs = es}</tt> might not mention
--   all visible fields. <tt>insertMissingFields</tt> inserts placeholders
--   for the missing visible fields and returns the values in order of the
--   fields in the record declaration.
insertMissingFieldsWarn :: forall a. HasRange a => QName -> (Name -> a) -> [FieldAssignment' a] -> [Arg Name] -> TCM [NamedArg a]

-- | A record field assignment <tt>record{xs = es}</tt> might not mention
--   all visible fields. <tt>insertMissingFields</tt> inserts placeholders
--   for the missing visible fields and returns the values in order of the
--   fields in the record declaration.
insertMissingFieldsFail :: forall a. HasRange a => QName -> (Name -> a) -> [FieldAssignment' a] -> [Arg Name] -> TCM [NamedArg a]

-- | Check if a name refers to a record. If yes, return record definition.
isRecord :: HasConstInfo m => QName -> m (Maybe RecordData)

-- | Get the definition for a record. Throws an exception if the name does
--   not refer to a record or the record is abstract.
getRecordDef :: (HasConstInfo m, ReadTCState m, MonadError TCErr m) => QName -> m RecordData

-- | Get the record name belonging to a field name.
getRecordOfField :: QName -> TCM (Maybe QName)

-- | Get the field names of a record.
getRecordFieldNames :: (HasConstInfo m, ReadTCState m, MonadError TCErr m) => QName -> m [Dom Name]
recordFieldNames :: RecordData -> [Dom Name]

-- | Find all records with at least the given fields.
findPossibleRecords :: [Name] -> TCM [QName]

-- | Get the field names belonging to a record type.
getRecordTypeFields :: Type -> TCM [Dom QName]

-- | Returns the given record type's constructor name (with an empty
--   range).
getRecordConstructor :: (HasConstInfo m, ReadTCState m, MonadError TCErr m) => QName -> m ConHead

-- | Reduce a type and check whether it is a record type. Succeeds only if
--   type is not blocked by a meta var. If yes, return its name,
--   parameters, and definition.
isRecordType :: PureTCM m => Type -> m (Maybe (QName, Args, RecordData))

-- | Reduce a type and check whether it is a record type. Succeeds only if
--   type is not blocked by a meta var. If yes, return its name,
--   parameters, and definition. If no, return the reduced type (unless it
--   is blocked).
tryRecordType :: PureTCM m => Type -> m (Either (Blocked Type) (QName, Args, RecordData))

-- | Get the original projection info for name.
origProjection :: HasConstInfo m => QName -> m (QName, Definition, Maybe Projection)

-- | <tt>getDefType f t</tt> computes the type of (possibly
--   projection-(like)) function <tt>f</tt> whose first argument has type
--   <tt>t</tt>. The <tt>parameters</tt> for <tt>f</tt> are extracted from
--   <tt>t</tt>. <tt>Nothing</tt> if <tt>f</tt> is projection(like) but
--   <tt>t</tt> is not a data<i>record</i>axiom type.
--   
--   Precondition: <tt>t</tt> is reduced.
--   
--   See also: <a>getConType</a>
getDefType :: PureTCM m => QName -> Type -> m (Maybe Type)

-- | Apply a projection to an expression with a known type, returning the
--   type of the projected value. The given type should either be a record
--   type or a type eligible for the principal argument of a
--   projection-like function.
shouldBeProjectible :: (PureTCM m, MonadTCError m, MonadBlock m) => Term -> Type -> ProjOrigin -> QName -> m Type

-- | The analogue of <a>piApply</a>. If <tt>v</tt> is a value of record
--   type <tt>t</tt> with field <tt>f</tt>, then <tt>projectTyped v t
--   f</tt> returns the type of <tt>f v</tt>. And also the record type (as
--   first result).
--   
--   Works also for projection-like definitions <tt>f</tt>. In this case,
--   the first result is not a record type.
--   
--   Precondition: <tt>t</tt> is reduced.
projectTyped :: PureTCM m => Term -> Type -> ProjOrigin -> QName -> m (Maybe (Dom Type, Term, Type))

-- | Typing of an elimination.
data ElimType

-- | Type of the argument.
ArgT :: Dom Type -> ElimType
ProjT :: Dom Type -> Type -> ElimType

-- | The type of the record which is eliminated.
[projTRec] :: ElimType -> Dom Type

-- | The type of the field.
[projTField] :: ElimType -> Type

-- | Given a head and its type, compute the types of the eliminations.
typeElims :: Type -> Term -> Elims -> TCM [ElimType]

-- | Given a term with a given type and a list of eliminations, returning
--   the type of the term applied to the eliminations.
eliminateType :: PureTCM m => m Empty -> Term -> Type -> Elims -> m Type
eliminateType' :: PureTCM m => m Empty -> (Elims -> Term) -> Type -> Elims -> m Type

-- | Check if a name refers to an eta expandable record.
--   
--   The answer is no for a record type with an erased constructor unless
--   the current quantity is "erased".
isEtaRecord :: HasConstInfo m => QName -> m Bool
isEtaRecordDef :: HasConstInfo m => RecordData -> m Bool
isEtaCon :: HasConstInfo m => QName -> m Bool

-- | Going under one of these does not count as a decrease in size for the
--   termination checker.
isEtaOrCoinductiveRecordConstructor :: HasConstInfo m => QName -> m Bool

-- | Check if a name refers to a record which is not coinductive.
--   (Projections are then size-preserving)
isInductiveRecord :: HasConstInfo m => QName -> m Bool

-- | Check if a type is an eta expandable record and return the record
--   identifier and the parameters.
isEtaRecordType :: HasConstInfo m => Type -> m (Maybe (QName, Args))

-- | Check if a name refers to a record constructor. If yes, return record
--   definition.
isRecordConstructor :: HasConstInfo m => QName -> m (Maybe (QName, RecordData))
isEtaRecordConstructor :: HasConstInfo m => QName -> m (Maybe (QName, RecordData))

-- | Turn off eta for unguarded recursive records. Projections do not
--   preserve guardedness.
unguardedRecord :: QName -> PatternOrCopattern -> TCM ()

-- | Turn on eta for non-recursive and inductive guarded recursive records,
--   unless user declared otherwise. Projections do not preserve
--   guardedness.
updateEtaForRecord :: QName -> TCM ()

-- | Turn on eta for inductive guarded recursive records. Projections do
--   not preserve guardedness.
recursiveRecord :: QName -> TCM ()

-- | Turn on eta for non-recursive record, unless user declared otherwise.
nonRecursiveRecord :: QName -> TCM ()

-- | Check whether record type is marked as recursive.
--   
--   Precondition: record type identifier exists in signature.
isRecursiveRecord :: QName -> TCM Bool

-- | <pre>
--   etaExpandBoundVar i = (Δ, σ, τ)
--   </pre>
--   
--   Precondition: The current context is <tt>Γ = Γ₁, x:R pars, Γ₂</tt>
--   where <tt>|Γ₂| = i</tt> and <tt>R</tt> is a eta-expandable record type
--   with constructor <tt>c</tt> and fields <tt>Γ'</tt>.
--   
--   Postcondition: <tt>Δ = Γ₁, Γ', Γ₂[c Γ']</tt> and <tt>Γ ⊢ σ : Δ</tt>
--   and <tt>Δ ⊢ τ : Γ</tt>.
etaExpandBoundVar :: Int -> TCM (Maybe (Telescope, Substitution, Substitution))

-- | <pre>
--   expandRecordVar i Γ = (Δ, σ, τ, Γ')
--   </pre>
--   
--   Precondition: <tt>Γ = Γ₁, x:R pars, Γ₂</tt> where <tt>|Γ₂| = i</tt>
--   and <tt>R</tt> is a eta-expandable record type with constructor
--   <tt>c</tt> and fields <tt>Γ'</tt>.
--   
--   Postcondition: <tt>Δ = Γ₁, Γ', Γ₂[c Γ']</tt> and <tt>Γ ⊢ σ : Δ</tt>
--   and <tt>Δ ⊢ τ : Γ</tt>.
expandRecordVar :: PureTCM m => Int -> Telescope -> m (Maybe (Telescope, Substitution, Substitution, Telescope))

-- | Precondition: variable list is ordered descendingly. Can be empty.
expandRecordVarsRecursively :: [Int] -> Telescope -> TCM (Telescope, Substitution, Substitution)

-- | <pre>
--   curryAt v (Γ (y : R pars) -&gt; B) n =
--        (  v -&gt; λ Γ ys → v Γ (c ys)            {- curry   -}
--        ,  v -&gt; λ Γ y → v Γ (p1 y) ... (pm y)  {- uncurry -}
--        , Γ (ys : As) → B[c ys / y]
--        )
--   </pre>
--   
--   where <tt>n = size Γ</tt>.
curryAt :: Type -> Int -> TCM (Term -> Term, Term -> Term, Type)

-- | <tt>etaExpand r pars u</tt> computes the eta expansion of record value
--   <tt>u</tt> at record type <tt>r pars</tt>.
--   
--   The first argument <tt>r</tt> should be the name of an eta-expandable
--   record type. Given
--   
--   <pre>
--   record R : Set where field x : A; y : B; .z : C
--   </pre>
--   
--   and <tt>r : R</tt>,
--   
--   <pre>
--   etaExpand R [] r = (tel, [R.x r, R.y r, R.z r])
--   </pre>
--   
--   where <tt>tel</tt> is the record telescope instantiated at the
--   parameters <tt>pars</tt>.
etaExpandRecord :: (HasConstInfo m, MonadDebug m, ReadTCState m) => QName -> Args -> Term -> m (Telescope, Args)

-- | Eta expand a record regardless of whether it's an eta-record or not.
forceEtaExpandRecord :: (HasConstInfo m, MonadDebug m, ReadTCState m, MonadError TCErr m) => QName -> Args -> Term -> m (Telescope, Args)

-- | Eta-expand a value at the given record type (must match).
etaExpandRecord' :: (HasConstInfo m, MonadDebug m, ReadTCState m) => Bool -> QName -> Args -> Term -> m (Telescope, Args)

-- | Eta-expand a value at the given eta record type (must match).
etaExpandRecord_ :: HasConstInfo m => QName -> Args -> RecordData -> Term -> m (Telescope, ConHead, ConInfo, Args)

-- | Eta-expand a value at the given record type (must match).
etaExpandRecord'_ :: HasConstInfo m => Bool -> QName -> Args -> RecordData -> Term -> m (Telescope, ConHead, ConInfo, Args)
etaExpandAtRecordType :: Type -> Term -> TCM (Telescope, Term)

-- | The fields should be eta contracted already.
--   
--   We can eta contract if all fields <tt>f = ...</tt> are irrelevant or
--   all fields <tt>f</tt> are the projection <tt>f v</tt> of the same
--   value <tt>v</tt>, but we need at least one relevant field to find the
--   value <tt>v</tt>.
--   
--   If all fields are erased, we cannot eta-contract.
etaContractRecord :: HasConstInfo m => QName -> ConHead -> ConInfo -> Args -> m Term

-- | Is the type a hereditarily singleton record type? May return a
--   blocking metavariable.
--   
--   Precondition: The name should refer to a record type, and the
--   arguments should be the parameters to the type.
isSingletonRecord :: (PureTCM m, MonadBlock m) => QName -> Args -> m Bool
isSingletonRecordModuloRelevance :: (PureTCM m, MonadBlock m) => QName -> Args -> m Bool

-- | Return the unique (closed) inhabitant if exists. In case of counting
--   irrelevance in, the returned inhabitant contains dummy terms.
isSingletonRecord' :: forall m. (PureTCM m, MonadBlock m) => Bool -> QName -> Args -> Set QName -> m (Maybe Term)

-- | Check whether a type has a unique inhabitant and return it. Can be
--   blocked by a metavar.
isSingletonType :: (PureTCM m, MonadBlock m) => Type -> m (Maybe Term)

-- | Check whether a type has a unique inhabitant (irrelevant parts
--   ignored). Can be blocked by a metavar.
isSingletonTypeModuloRelevance :: (PureTCM m, MonadBlock m) => Type -> m Bool
isSingletonType' :: forall m. (PureTCM m, MonadBlock m) => Bool -> Type -> Set QName -> m (Maybe Term)

-- | Checks whether the given term (of the given type) is
--   beta-eta-equivalent to a variable. Returns just the de Bruijn-index of
--   the variable if it is, or nothing otherwise.
isEtaVar :: forall m. PureTCM m => Term -> Type -> m (Maybe Int)

-- | Replace projection patterns by the original projections.
class NormaliseProjP a
normaliseProjP :: (NormaliseProjP a, HasConstInfo m) => a -> m a
instance Agda.TypeChecking.Records.NormaliseProjP Agda.Syntax.Internal.Clause
instance Agda.TypeChecking.Records.NormaliseProjP a => Agda.TypeChecking.Records.NormaliseProjP [a]
instance Agda.TypeChecking.Records.NormaliseProjP a => Agda.TypeChecking.Records.NormaliseProjP (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Records.NormaliseProjP a => Agda.TypeChecking.Records.NormaliseProjP (Agda.Syntax.Common.Named_ a)
instance Agda.TypeChecking.Records.NormaliseProjP (Agda.Syntax.Internal.Pattern' x)
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Records.ElimType

module Agda.TypeChecking.Rules.LHS.Problem
type FlexibleVars = [FlexibleVar Nat]

-- | When we encounter a flexible variable in the unifier, where did it
--   come from? The alternatives are ordered such that we will assign the
--   higher one first, i.e., first we try to assign a <tt>DotFlex</tt>,
--   then...
data FlexibleVarKind

-- | From a record pattern (<a>ConP</a>). Saves the <a>FlexibleVarKind</a>
--   of its subpatterns.
RecordFlex :: [FlexibleVarKind] -> FlexibleVarKind

-- | From a hidden formal argument or underscore (<tt>WildP</tt>).
ImplicitFlex :: FlexibleVarKind

-- | From a dot pattern (<a>DotP</a>).
DotFlex :: FlexibleVarKind

-- | From a non-record constructor or literal (<a>ConP</a> or <a>LitP</a>).
OtherFlex :: FlexibleVarKind

-- | Flexible variables are equipped with information where they come from,
--   in order to make a choice which one to assign when two flexibles are
--   unified.
data FlexibleVar a
FlexibleVar :: ArgInfo -> IsForced -> FlexibleVarKind -> Maybe Int -> a -> FlexibleVar a
[flexArgInfo] :: FlexibleVar a -> ArgInfo
[flexForced] :: FlexibleVar a -> IsForced
[flexKind] :: FlexibleVar a -> FlexibleVarKind
[flexPos] :: FlexibleVar a -> Maybe Int
[flexVar] :: FlexibleVar a -> a
allFlexVars :: [IsForced] -> Telescope -> FlexibleVars
data FlexChoice
ChooseLeft :: FlexChoice
ChooseRight :: FlexChoice
ChooseEither :: FlexChoice
ExpandBoth :: FlexChoice
class ChooseFlex a
chooseFlex :: ChooseFlex a => a -> a -> FlexChoice

-- | A user pattern together with an internal term that it should be equal
--   to after splitting is complete. Special cases: * User pattern is a
--   variable but internal term isn't: this will be turned into an as
--   pattern. * User pattern is a dot pattern: this pattern won't trigger
--   any splitting but will be checked for equality after all splitting is
--   complete and as patterns have been bound. * User pattern is an absurd
--   pattern: emptiness of the type will be checked after splitting is
--   complete. * User pattern is an annotated wildcard: type annotation
--   will be checked after splitting is complete.
data ProblemEq
ProblemEq :: Pattern -> Term -> Dom Type -> ProblemEq
[problemInPat] :: ProblemEq -> Pattern
[problemInst] :: ProblemEq -> Term
[problemType] :: ProblemEq -> Dom Type

-- | The user patterns we still have to split on.
data Problem a
Problem :: [ProblemEq] -> [NamedArg Pattern] -> (LHSState a -> TCM a) -> Problem a

-- | User patterns which are typed (including the ones generated from
--   implicit arguments).
[_problemEqs] :: Problem a -> [ProblemEq]

-- | List of user patterns which could not yet be typed. Example: <tt> f :
--   (b : Bool) -&gt; if b then Nat else Nat -&gt; Nat f true = zero f
--   false zero = zero f false (suc n) = n </tt> In this sitation, for
--   clause 2, we construct an initial problem <tt> problemEqs = [false =
--   b] problemRestPats = [zero] </tt> As we instantiate <tt>b</tt> to
--   <tt>false</tt>, the <tt>targetType</tt> reduces to <tt>Nat -&gt;
--   Nat</tt> and we can move pattern <tt>zero</tt> over to
--   <tt>problemEqs</tt>.
[_problemRestPats] :: Problem a -> [NamedArg Pattern]

-- | The code that checks the RHS.
[_problemCont] :: Problem a -> LHSState a -> TCM a
problemEqs :: Lens' (Problem a) [ProblemEq]
problemRestPats :: Lens' (Problem a) [NamedArg Pattern]
problemCont :: Lens' (Problem a) (LHSState a -> TCM a)
problemInPats :: Problem a -> [Pattern]
data AsBinding
AsB :: Name -> Term -> Type -> Modality -> AsBinding
data DotPattern
Dot :: Expr -> Term -> Dom Type -> DotPattern
data AbsurdPattern
Absurd :: Range -> Type -> AbsurdPattern
data AnnotationPattern
Ann :: Expr -> Type -> AnnotationPattern

-- | State worked on during the main loop of checking a lhs. [Ulf Norell's
--   PhD, page. 35]
data LHSState a
LHSState :: Telescope -> [NamedArg DeBruijnPattern] -> Problem a -> Arg Type -> ![Maybe Int] -> !Bool -> LHSState a

-- | The types of the pattern variables.
[_lhsTel] :: LHSState a -> Telescope

-- | Patterns after splitting. The de Bruijn indices refer to positions in
--   the list of abstract syntax patterns in the problem, counted from the
--   back (right-to-left).
[_lhsOutPat] :: LHSState a -> [NamedArg DeBruijnPattern]

-- | User patterns of supposed type <tt>delta</tt>.
[_lhsProblem] :: LHSState a -> Problem a

-- | Type eliminated by <a>problemRestPats</a> in the problem. Can be
--   <a>Irrelevant</a> to indicate that we came by an irrelevant projection
--   and, hence, the rhs must be type-checked in irrelevant mode.
[_lhsTarget] :: LHSState a -> Arg Type

-- | have we splitted with a PartialFocus?
[_lhsPartialSplit] :: LHSState a -> ![Maybe Int]

-- | Have we split on any indexed inductive types?
[_lhsIndexedSplit] :: LHSState a -> !Bool
lhsTel :: Lens' (LHSState a) Telescope
lhsOutPat :: Lens' (LHSState a) [NamedArg DeBruijnPattern]
lhsProblem :: Lens' (LHSState a) (Problem a)
lhsTarget :: Lens' (LHSState a) (Arg Type)
data LeftoverPatterns
LeftoverPatterns :: IntMap [(Name, PatVarPosition)] -> [AsBinding] -> [DotPattern] -> [AbsurdPattern] -> [AnnotationPattern] -> [Pattern] -> LeftoverPatterns
[patternVariables] :: LeftoverPatterns -> IntMap [(Name, PatVarPosition)]
[asPatterns] :: LeftoverPatterns -> [AsBinding]
[dotPatterns] :: LeftoverPatterns -> [DotPattern]
[absurdPatterns] :: LeftoverPatterns -> [AbsurdPattern]
[typeAnnotations] :: LeftoverPatterns -> [AnnotationPattern]
[otherPatterns] :: LeftoverPatterns -> [Pattern]

-- | Classify remaining patterns after splitting is complete into pattern
--   variables, as patterns, dot patterns, and absurd patterns.
--   Precondition: there are no more constructor patterns.
getLeftoverPatterns :: forall m. PureTCM m => [ProblemEq] -> m LeftoverPatterns

-- | Build a renaming for the internal patterns using variable names from
--   the user patterns. If there are multiple user names for the same
--   internal variable, the unused ones are returned as as-bindings. Names
--   that are not also module parameters are preferred over those that are.
getUserVariableNames :: Telescope -> IntMap [(Name, PatVarPosition)] -> ([Maybe Name], [AsBinding])
instance GHC.Show.Show Agda.TypeChecking.Rules.LHS.Problem.FlexibleVarKind
instance GHC.Classes.Eq Agda.TypeChecking.Rules.LHS.Problem.FlexibleVarKind
instance Data.Traversable.Traversable Agda.TypeChecking.Rules.LHS.Problem.FlexibleVar
instance Data.Foldable.Foldable Agda.TypeChecking.Rules.LHS.Problem.FlexibleVar
instance GHC.Base.Functor Agda.TypeChecking.Rules.LHS.Problem.FlexibleVar
instance GHC.Show.Show a => GHC.Show.Show (Agda.TypeChecking.Rules.LHS.Problem.FlexibleVar a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.TypeChecking.Rules.LHS.Problem.FlexibleVar a)
instance GHC.Show.Show Agda.TypeChecking.Rules.LHS.Problem.FlexChoice
instance GHC.Classes.Eq Agda.TypeChecking.Rules.LHS.Problem.FlexChoice
instance GHC.Show.Show (Agda.TypeChecking.Rules.LHS.Problem.Problem a)
instance GHC.Classes.Eq Agda.TypeChecking.Rules.LHS.Problem.PatVarPosition
instance GHC.Show.Show Agda.TypeChecking.Rules.LHS.Problem.PatVarPosition
instance GHC.Base.Semigroup Agda.TypeChecking.Rules.LHS.Problem.LeftoverPatterns
instance Agda.Utils.Null.Null Agda.TypeChecking.Rules.LHS.Problem.LeftoverPatterns
instance GHC.Base.Monoid Agda.TypeChecking.Rules.LHS.Problem.LeftoverPatterns
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Rules.LHS.Problem.LeftoverPatterns
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Rules.LHS.Problem.PatVarPosition
instance Agda.TypeChecking.Substitute.Class.Subst (Agda.TypeChecking.Rules.LHS.Problem.Problem a)
instance Agda.TypeChecking.Pretty.PrettyTCM (Agda.TypeChecking.Rules.LHS.Problem.LHSState a)
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Rules.LHS.Problem.AnnotationPattern
instance Agda.TypeChecking.Substitute.Class.Subst Agda.TypeChecking.Rules.LHS.Problem.AbsurdPattern
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Rules.LHS.Problem.AbsurdPattern
instance Agda.TypeChecking.Substitute.Class.Subst Agda.TypeChecking.Rules.LHS.Problem.DotPattern
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Rules.LHS.Problem.DotPattern
instance Agda.TypeChecking.Substitute.Class.Subst Agda.TypeChecking.Rules.LHS.Problem.AsBinding
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Rules.LHS.Problem.AsBinding
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Rules.LHS.Problem.AsBinding
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Rules.LHS.Problem.AsBinding
instance Agda.TypeChecking.Rules.LHS.Problem.ChooseFlex Agda.TypeChecking.Rules.LHS.Problem.FlexibleVarKind
instance Agda.TypeChecking.Rules.LHS.Problem.ChooseFlex a => Agda.TypeChecking.Rules.LHS.Problem.ChooseFlex [a]
instance Agda.TypeChecking.Rules.LHS.Problem.ChooseFlex a => Agda.TypeChecking.Rules.LHS.Problem.ChooseFlex (GHC.Maybe.Maybe a)
instance Agda.TypeChecking.Rules.LHS.Problem.ChooseFlex Agda.Syntax.Common.ArgInfo
instance Agda.TypeChecking.Rules.LHS.Problem.ChooseFlex Agda.TypeChecking.Monad.Base.IsForced
instance Agda.TypeChecking.Rules.LHS.Problem.ChooseFlex Agda.Syntax.Common.Hiding
instance Agda.TypeChecking.Rules.LHS.Problem.ChooseFlex Agda.Syntax.Common.Origin
instance Agda.TypeChecking.Rules.LHS.Problem.ChooseFlex GHC.Types.Int
instance Agda.TypeChecking.Rules.LHS.Problem.ChooseFlex a => Agda.TypeChecking.Rules.LHS.Problem.ChooseFlex (Agda.TypeChecking.Rules.LHS.Problem.FlexibleVar a)
instance GHC.Base.Semigroup Agda.TypeChecking.Rules.LHS.Problem.FlexChoice
instance GHC.Base.Monoid Agda.TypeChecking.Rules.LHS.Problem.FlexChoice
instance Agda.Syntax.Common.LensArgInfo (Agda.TypeChecking.Rules.LHS.Problem.FlexibleVar a)
instance Agda.Syntax.Common.LensHiding (Agda.TypeChecking.Rules.LHS.Problem.FlexibleVar a)
instance Agda.Syntax.Common.LensOrigin (Agda.TypeChecking.Rules.LHS.Problem.FlexibleVar a)
instance Agda.Syntax.Common.LensModality (Agda.TypeChecking.Rules.LHS.Problem.FlexibleVar a)
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Syntax.Abstract.ProblemEq

module Agda.TypeChecking.Rules.LHS.Unify.Types
data Equality
Equal :: Dom Type -> Term -> Term -> Equality
[_eqType] :: Equality -> Dom Type
[_eqLeft] :: Equality -> Term
[_eqRight] :: Equality -> Term
eqConstructorForm :: HasBuiltins m => Equality -> m Equality
eqUnLevel :: (HasBuiltins m, HasOptions m) => Equality -> m Equality
data UnifyState
UState :: Telescope -> FlexibleVars -> Telescope -> [Arg Term] -> [Arg Term] -> UnifyState

-- | Don't reduce!
[varTel] :: UnifyState -> Telescope
[flexVars] :: UnifyState -> FlexibleVars

-- | Can be reduced eagerly.
[eqTel] :: UnifyState -> Telescope

-- | Ends up in dot patterns (should not be reduced eagerly).
[eqLHS] :: UnifyState -> [Arg Term]

-- | Ends up in dot patterns (should not be reduced eagerly).
[eqRHS] :: UnifyState -> [Arg Term]
lensVarTel :: Lens' UnifyState Telescope
lensEqTel :: Lens' UnifyState Telescope
initUnifyState :: PureTCM m => Telescope -> FlexibleVars -> Type -> Args -> Args -> m UnifyState
isUnifyStateSolved :: UnifyState -> Bool
varCount :: UnifyState -> Int

-- | Get the type of the i'th variable in the given state
getVarType :: Int -> UnifyState -> Dom Type
getVarTypeUnraised :: Int -> UnifyState -> Dom Type
eqCount :: UnifyState -> Int

-- | Get the k'th equality in the given state. The left- and right-hand
--   sides of the equality live in the varTel telescope, and the type of
--   the equality lives in the varTel++eqTel telescope
getEquality :: Int -> UnifyState -> Equality
getReducedEquality :: (MonadReduce m, MonadAddContext m) => Int -> UnifyState -> m Equality

-- | As getEquality, but with the unraised type
getEqualityUnraised :: Int -> UnifyState -> Equality
getReducedEqualityUnraised :: (MonadReduce m, MonadAddContext m) => Int -> UnifyState -> m Equality

-- | Instantiate the k'th variable with the given value. Returns Nothing if
--   there is a cycle.
solveVar :: Int -> DeBruijnPattern -> UnifyState -> Maybe (UnifyState, PatternSubstitution)
applyUnder :: Int -> Telescope -> Term -> Telescope
dropAt :: Int -> [a] -> [a]

-- | Solve the k'th equation with the given value, which can depend on
--   regular variables but not on other equation variables.
solveEq :: Int -> Term -> UnifyState -> (UnifyState, PatternSubstitution)
data UnifyStep
Deletion :: Int -> Type -> Term -> Term -> UnifyStep
[deleteAt] :: UnifyStep -> Int
[deleteType] :: UnifyStep -> Type
[deleteLeft] :: UnifyStep -> Term
[deleteRight] :: UnifyStep -> Term
Solution :: Int -> Dom Type -> FlexibleVar Int -> Term -> Either () () -> UnifyStep
[solutionAt] :: UnifyStep -> Int
[solutionType] :: UnifyStep -> Dom Type
[solutionVar] :: UnifyStep -> FlexibleVar Int
[solutionTerm] :: UnifyStep -> Term

-- | side of the equation where the variable is.
[solutionSide] :: UnifyStep -> Either () ()
Injectivity :: Int -> Type -> QName -> Args -> Args -> ConHead -> UnifyStep
[injectAt] :: UnifyStep -> Int
[injectType] :: UnifyStep -> Type
[injectDatatype] :: UnifyStep -> QName
[injectParameters] :: UnifyStep -> Args
[injectIndices] :: UnifyStep -> Args
[injectConstructor] :: UnifyStep -> ConHead
Conflict :: Int -> Type -> QName -> Args -> Term -> Term -> UnifyStep
[conflictAt] :: UnifyStep -> Int
[conflictType] :: UnifyStep -> Type
[conflictDatatype] :: UnifyStep -> QName
[conflictParameters] :: UnifyStep -> Args
[conflictLeft] :: UnifyStep -> Term
[conflictRight] :: UnifyStep -> Term
Cycle :: Int -> Type -> QName -> Args -> Int -> Term -> UnifyStep
[cycleAt] :: UnifyStep -> Int
[cycleType] :: UnifyStep -> Type
[cycleDatatype] :: UnifyStep -> QName
[cycleParameters] :: UnifyStep -> Args
[cycleVar] :: UnifyStep -> Int
[cycleOccursIn] :: UnifyStep -> Term
EtaExpandVar :: FlexibleVar Int -> QName -> Args -> UnifyStep
[expandVar] :: UnifyStep -> FlexibleVar Int
[expandVarRecordType] :: UnifyStep -> QName
[expandVarParameters] :: UnifyStep -> Args
EtaExpandEquation :: Int -> QName -> Args -> UnifyStep
[expandAt] :: UnifyStep -> Int
[expandRecordType] :: UnifyStep -> QName
[expandParameters] :: UnifyStep -> Args
LitConflict :: Int -> Type -> Literal -> Literal -> UnifyStep
[litConflictAt] :: UnifyStep -> Int
[litType] :: UnifyStep -> Type
[litConflictLeft] :: UnifyStep -> Literal
[litConflictRight] :: UnifyStep -> Literal
StripSizeSuc :: Int -> Term -> Term -> UnifyStep
[stripAt] :: UnifyStep -> Int
[stripArgLeft] :: UnifyStep -> Term
[stripArgRight] :: UnifyStep -> Term
SkipIrrelevantEquation :: Int -> UnifyStep
[skipIrrelevantAt] :: UnifyStep -> Int
TypeConInjectivity :: Int -> QName -> Args -> Args -> UnifyStep
[typeConInjectAt] :: UnifyStep -> Int
[typeConstructor] :: UnifyStep -> QName
[typeConArgsLeft] :: UnifyStep -> Args
[typeConArgsRight] :: UnifyStep -> Args
data UnifyLogEntry
UnificationStep :: UnifyState -> UnifyStep -> UnifyOutput -> UnifyLogEntry
type UnifyLog = [(UnifyLogEntry, UnifyState)]

-- | This variant of <a>UnifyLog</a> is used to ensure that <a>tell</a> is
--   not expensive.
type UnifyLog' = DList (UnifyLogEntry, UnifyState)
data UnifyOutput
UnifyOutput :: PatternSubstitution -> PatternSubstitution -> UnifyOutput
[unifySubst] :: UnifyOutput -> PatternSubstitution
[unifyProof] :: UnifyOutput -> PatternSubstitution
type UnifyLogT m a = WriterT UnifyLog' m a
type UnifyStepT m a = WriterT UnifyOutput m a
tellUnifySubst :: MonadWriter UnifyOutput m => PatternSubstitution -> m ()
tellUnifyProof :: MonadWriter UnifyOutput m => PatternSubstitution -> m ()
writeUnifyLog :: MonadWriter UnifyLog' m => (UnifyLogEntry, UnifyState) -> m ()
runUnifyLogT :: Functor m => UnifyLogT m a -> m (a, UnifyLog)
instance GHC.Show.Show Agda.TypeChecking.Rules.LHS.Unify.Types.UnifyState
instance GHC.Show.Show Agda.TypeChecking.Rules.LHS.Unify.Types.UnifyStep
instance GHC.Base.Semigroup Agda.TypeChecking.Rules.LHS.Unify.Types.UnifyOutput
instance GHC.Base.Monoid Agda.TypeChecking.Rules.LHS.Unify.Types.UnifyOutput
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Rules.LHS.Unify.Types.UnifyStep
instance Agda.TypeChecking.Reduce.Reduce Agda.TypeChecking.Rules.LHS.Unify.Types.UnifyState
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Rules.LHS.Unify.Types.UnifyState

module Agda.TypeChecking.Rules.LHS.Unify.LeftInverse
data NoLeftInv
UnsupportedYet :: UnifyStep -> NoLeftInv
[badStep] :: NoLeftInv -> UnifyStep
Illegal :: UnifyStep -> NoLeftInv
[badStep] :: NoLeftInv -> UnifyStep
NoCubical :: NoLeftInv
WithKEnabled :: NoLeftInv

-- | splitting on a Strict Set.
SplitOnStrict :: NoLeftInv

-- | splitting on a @♭ argument
SplitOnFlat :: NoLeftInv
UnsupportedCxt :: NoLeftInv
buildLeftInverse :: (PureTCM tcm, MonadError TCErr tcm) => UnifyState -> UnifyLog -> tcm (Either NoLeftInv (Substitution, Substitution))
type Retract = (Telescope, Substitution, Substitution, Substitution)
termsS :: DeBruijn a => Impossible -> [a] -> Substitution' a
composeRetract :: (PureTCM tcm, MonadError TCErr tcm, MonadDebug tcm, HasBuiltins tcm, MonadAddContext tcm) => Retract -> Term -> Retract -> tcm Retract
buildEquiv :: forall tcm. (PureTCM tcm, MonadError TCErr tcm) => UnifyLogEntry -> UnifyState -> tcm (Either NoLeftInv (Retract, Term))
explainStep :: MonadPretty m => UnifyStep -> m Doc
instance GHC.Show.Show Agda.TypeChecking.Rules.LHS.Unify.LeftInverse.NoLeftInv
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Rules.LHS.Unify.LeftInverse.NoLeftInv


-- | Pattern matcher used in the reducer for clauses that have not been
--   compiled to case trees yet.
module Agda.TypeChecking.Patterns.Match

-- | If matching is inconclusive (<tt>DontKnow</tt>) we want to know
--   whether it is on a lazy pattern and whether it is due to a particular
--   meta variable.
data Match a
Yes :: Simplification -> IntMap (Arg a) -> Match a
No :: Match a
DontKnow :: OnlyLazy -> Blocked () -> Match a
matchedArgs :: Empty -> Int -> IntMap (Arg a) -> [Arg a]
matchedArgs' :: Int -> IntMap (Arg a) -> [Maybe (Arg a)]

-- | Builds a proper substitution from an IntMap produced by
--   match(Co)patterns
buildSubstitution :: DeBruijn a => Impossible -> Int -> IntMap (Arg a) -> Substitution' a

-- | Whether the inconclusive matches are only on lazy patterns.
data OnlyLazy
OnlyLazy :: OnlyLazy
NonLazy :: OnlyLazy

-- | Instead of <a>zipWithM</a>, we need to use this lazy version of
--   combining pattern matching computations.
foldMatch :: forall m p v. (IsProjP p, MonadMatch m) => (p -> v -> m (Match Term, v)) -> [p] -> [v] -> m (Match Term, [v])
mergeElim :: Elim -> Arg Term -> Elim
mergeElims :: [Elim] -> [Arg Term] -> [Elim]
type MonadMatch m = PureTCM m

-- | <tt>matchCopatterns ps es</tt> matches spine <tt>es</tt> against
--   copattern spine <tt>ps</tt>.
--   
--   Returns <a>Yes</a> and a substitution for the pattern variables (in
--   form of IntMap Term) if matching was successful.
--   
--   Returns <a>No</a> if there was a constructor or projection mismatch.
--   
--   Returns <a>DontKnow</a> if an argument could not be evaluated to
--   constructor form because of a blocking meta variable.
--   
--   In any case, also returns spine <tt>es</tt> in reduced form (with all
--   the weak head reductions performed that were necessary to come to a
--   decision).
matchCopatterns :: MonadMatch m => [NamedArg DeBruijnPattern] -> [Elim] -> m (Match Term, [Elim])

-- | Match a single copattern.
matchCopattern :: MonadMatch m => DeBruijnPattern -> Elim -> m (Match Term, Elim)
matchPatterns :: MonadMatch m => [NamedArg DeBruijnPattern] -> [Arg Term] -> m (Match Term, [Arg Term])

-- | Match a single pattern.
matchPattern :: MonadMatch m => DeBruijnPattern -> Arg Term -> m (Match Term, Arg Term)
yesSimplification :: Match a -> Match a

-- | Match a single pattern.
matchPatternP :: MonadMatch m => DeBruijnPattern -> Arg DeBruijnPattern -> m (Match DeBruijnPattern)
matchPatternsP :: MonadMatch m => [NamedArg DeBruijnPattern] -> [Arg DeBruijnPattern] -> m (Match DeBruijnPattern)
instance GHC.Base.Functor Agda.TypeChecking.Patterns.Match.Match
instance Agda.Utils.Null.Null (Agda.TypeChecking.Patterns.Match.Match a)
instance GHC.Base.Semigroup (Agda.TypeChecking.Patterns.Match.Match a)
instance GHC.Base.Monoid (Agda.TypeChecking.Patterns.Match.Match a)
instance GHC.Base.Semigroup Agda.TypeChecking.Patterns.Match.OnlyLazy
instance GHC.Base.Monoid Agda.TypeChecking.Patterns.Match.OnlyLazy


-- | Functions for inserting implicit arguments at the right places.
module Agda.TypeChecking.Implicit

-- | Insert implicit binders in a list of binders, but not at the end.
insertImplicitBindersT :: (PureTCM m, MonadError TCErr m, MonadFresh NameId m, MonadTrace m) => [NamedArg Binder] -> Type -> m [NamedArg Binder]

-- | Insert implicit binders in a list of binders, but not at the end.
insertImplicitBindersT1 :: (PureTCM m, MonadError TCErr m, MonadFresh NameId m, MonadTrace m) => List1 (NamedArg Binder) -> Type -> m (List1 (NamedArg Binder))

-- | <tt>implicitArgs n expand t</tt> generates up to <tt>n</tt> implicit
--   argument metas (unbounded if <tt>n&lt;0</tt>), as long as <tt>t</tt>
--   is a function type and <tt>expand</tt> holds on the hiding info of its
--   domain.
implicitArgs :: (PureTCM m, MonadMetaSolver m, MonadTCM m) => Int -> (Hiding -> Bool) -> Type -> m (Args, Type)

-- | <tt>implicitNamedArgs n expand t</tt> generates up to <tt>n</tt> named
--   implicit arguments metas (unbounded if <tt>n&lt;0</tt>), as long as
--   <tt>t</tt> is a function type and <tt>expand</tt> holds on the hiding
--   and name info of its domain.
implicitNamedArgs :: (PureTCM m, MonadMetaSolver m, MonadTCM m) => Int -> (Hiding -> ArgName -> Bool) -> Type -> m (NamedArgs, Type)

-- | Create a metavariable of <a>MetaKind</a>.
newMetaArg :: (PureTCM m, MonadMetaSolver m) => MetaKind -> ArgInfo -> ArgName -> Comparison -> Type -> m (MetaId, Term)

-- | Create a questionmark (always <a>UnificationMeta</a>).
newInteractionMetaArg :: ArgInfo -> ArgName -> Comparison -> Type -> TCM (MetaId, Term)

-- | Possible results of <a>insertImplicit</a>.
data ImplicitInsertion

-- | Success: this many implicits have to be inserted (list can be empty).
ImpInsert :: [Dom ()] -> ImplicitInsertion

-- | Error: hidden argument where there should have been a non-hidden
--   argument.
BadImplicits :: ImplicitInsertion

-- | Error: bad named argument.
NoSuchName :: ArgName -> ImplicitInsertion
pattern NoInsertNeeded :: ImplicitInsertion

-- | If the next given argument is <tt>a</tt> and the expected arguments
--   are <tt>ts</tt> <tt>insertImplicit' a ts</tt> returns the prefix of
--   <tt>ts</tt> that precedes <tt>a</tt>.
--   
--   If <tt>a</tt> is named but this name does not appear in <tt>ts</tt>,
--   the <a>NoSuchName</a> exception is thrown.
insertImplicit :: NamedArg e -> [Dom a] -> ImplicitInsertion

-- | If the next given argument is <tt>a</tt> and the expected arguments
--   are <tt>ts</tt> <tt>insertImplicit' a ts</tt> returns the prefix of
--   <tt>ts</tt> that precedes <tt>a</tt>.
--   
--   If <tt>a</tt> is named but this name does not appear in <tt>ts</tt>,
--   the <a>NoSuchName</a> exception is thrown.
insertImplicit' :: NamedArg e -> [Dom ArgName] -> ImplicitInsertion
instance GHC.Show.Show Agda.TypeChecking.Implicit.ImplicitInsertion

module Agda.TypeChecking.Rules.LHS.Implicit
implicitP :: ArgInfo -> NamedArg Pattern

-- | Insert implicit patterns in a list of patterns. Even if
--   <a>DontExpandLast</a>, trailing SIZELT patterns are inserted.
insertImplicitPatterns :: (PureTCM m, MonadError TCErr m, MonadFresh NameId m, MonadTrace m) => ExpandHidden -> [NamedArg Pattern] -> Telescope -> m [NamedArg Pattern]

-- | Insert trailing SizeLt patterns, if any.
insertImplicitSizeLtPatterns :: PureTCM m => Type -> m [NamedArg Pattern]

-- | Insert implicit patterns in a list of patterns. Even if
--   <a>DontExpandLast</a>, trailing SIZELT patterns are inserted.
insertImplicitPatternsT :: (PureTCM m, MonadError TCErr m, MonadFresh NameId m, MonadTrace m) => ExpandHidden -> [NamedArg Pattern] -> Type -> m [NamedArg Pattern]

module Agda.TypeChecking.Rules.LHS.ProblemRest

-- | Rename the variables in a telescope using the names from a given
--   pattern.
--   
--   If there are not at least as many patterns as entries as in the
--   telescope, the names of the remaining entries in the telescope are
--   unchanged. If there are too many patterns, there should be a type
--   error later.
useNamesFromPattern :: [NamedArg Pattern] -> Telescope -> Telescope
useNamesFromProblemEqs :: forall m. PureTCM m => [ProblemEq] -> Telescope -> m Telescope
useOriginFrom :: (LensOrigin a, LensOrigin b) => [a] -> [b] -> [a]

-- | Are there any untyped user patterns left?
noProblemRest :: Problem a -> Bool

-- | Construct an initial <a>LHSState</a> from user patterns. Example: @
--   
--   Case : {A : Set} → Maybe A → Set → Set → Set Case nothing B C = B Case
--   (just _) B C = C
--   
--   sample : {A : Set} (m : Maybe A) → Case m Bool (Maybe A → Bool) sample
--   (just a) (just b) = true sample (just a) nothing = false sample
--   nothing = true <tt> The problem generated for the first clause of
--   </tt>sample<tt> with patterns </tt>just a, just b<tt> would be: </tt>
--   lhsTel = [A : Set, m : Maybe A] lhsOutPat = [<a>A</a>, "m"] lhsProblem
--   = Problem [<a>A</a> = _, "just a" = "a"] ["_", "just a"] ["just b"] []
--   lhsTarget = "Case m Bool (Maybe A -&gt; Bool)" @
initLHSState :: Telescope -> [ProblemEq] -> [NamedArg Pattern] -> Type -> (LHSState a -> TCM a) -> TCM (LHSState a)

-- | Try to move patterns from the problem rest into the problem. Possible
--   if type of problem rest has been updated to a function type.
updateProblemRest :: forall m a. (PureTCM m, MonadError TCErr m, MonadTrace m, MonadFresh NameId m) => LHSState a -> m (LHSState a)

module Agda.TypeChecking.Functions

-- | Expand a clause to the maximal arity, by inserting variable patterns
--   and applying the body to variables.
etaExpandClause :: MonadTCM tcm => Clause -> tcm Clause

-- | Get the name of defined symbol of the head normal form of a term.
--   Returns <a>Nothing</a> if no such head exists.
getDef :: Term -> TCM (Maybe QName)


-- | Imperfect discrimination trees for indexing data by internal syntax.
module Agda.TypeChecking.DiscrimTree

-- | Insert a value into the discrimination tree, turning variables into
--   rigid locals or wildcards depending on the given scope.
insertDT :: (Ord a, PrettyTCM a) => Int -> Term -> a -> DiscrimTree a -> TCM (DiscrimTree a)

-- | Look up a <a>Term</a> in the given discrimination tree, treating local
--   variables as rigid symbols. The returned set is guaranteed to contain
--   everything that could overlap the given key.
lookupDT :: forall a. (Ord a, PrettyTCM a) => Term -> DiscrimTree a -> TCM (QueryResult a)

-- | Look up a <a>Term</a> in the given discrimination tree, treating local
--   variables as wildcards.
lookupUnifyDT :: forall a. (Ord a, PrettyTCM a) => Term -> DiscrimTree a -> TCM (QueryResult a)
data QueryResult a
QueryResult :: Set a -> Blocker -> QueryResult a
[resultValues] :: QueryResult a -> Set a
[resultBlocker] :: QueryResult a -> Blocker

-- | Remove a set of values from the discrimination tree. The tree is
--   rebuilt so that cases with no leaves are removed.
deleteFromDT :: Ord a => DiscrimTree a -> Set a -> DiscrimTree a
instance GHC.Classes.Ord a => GHC.Base.Semigroup (Agda.TypeChecking.DiscrimTree.QueryResult a)
instance GHC.Classes.Ord a => GHC.Base.Monoid (Agda.TypeChecking.DiscrimTree.QueryResult a)

module Agda.TypeChecking.Datatypes

-- | Get true constructor with record fields.
getConHead :: HasConstInfo m => QName -> m (Either SigError ConHead)
isConstructor :: HasConstInfo m => QName -> m Bool

-- | Get true constructor with fields, expanding literals to constructors
--   if possible.
getConForm :: QName -> TCM (Either SigError ConHead)

-- | Augment constructor with record fields (preserve constructor name).
--   The true constructor might only surface via <a>reduce</a>.
getOrigConHead :: QName -> TCM (Either SigError ConHead)

-- | Get the name of the datatype constructed by a given constructor.
--   Precondition: The argument must refer to a constructor
getConstructorData :: HasConstInfo m => QName -> m QName

-- | Is the datatype of this constructor a Higher Inductive Type?
--   Precondition: The argument must refer to a constructor of a datatype
--   or record.
consOfHIT :: HasConstInfo m => QName -> m Bool
isPathCons :: HasConstInfo m => QName -> m Bool

-- | <tt>getFullyAppliedConType c t</tt> computes the constructor
--   parameters from data type <tt>t</tt> and returns them plus the
--   instantiated type of constructor <tt>c</tt>.
--   
--   <tt>Nothing</tt> if <tt>t</tt> is not a data/record type or does not
--   have a constructor <tt>c</tt>.
--   
--   Precondition: <tt>t</tt> is reduced.
getFullyAppliedConType :: PureTCM m => ConHead -> Type -> m (Maybe ((QName, Type, Args), Type))

-- | Make sure a constructor is fully applied and infer the type of the
--   constructor. Raises a type error if the constructor does not belong to
--   the given type.
fullyApplyCon :: (PureTCM m, MonadBlock m, MonadTCError m) => ConHead -> Elims -> Type -> (QName -> Type -> Args -> Type -> Elims -> Telescope -> Type -> m a) -> m a

-- | Like <tt>fullyApplyCon</tt>, but calls the given fallback function if
--   it encounters something other than a datatype.
fullyApplyCon' :: (PureTCM m, MonadBlock m) => ConHead -> Elims -> Type -> (QName -> Type -> Args -> Type -> Elims -> Telescope -> Type -> m a) -> (Type -> m a) -> m a

-- | <tt>getConType c t</tt> computes the constructor parameters from type
--   <tt>t</tt> and returns them plus the instantiated type of constructor
--   <tt>c</tt>. This works also if <tt>t</tt> is a function type ending in
--   a data/record type; the term from which <tt>c</tt> comes need not be
--   fully applied
--   
--   <tt>Nothing</tt> if <tt>t</tt> is not a data/record type or does not
--   have a constructor <tt>c</tt>.
getConType :: (PureTCM m, MonadBlock m) => ConHead -> Type -> m (Maybe ((QName, Type, Args), Type))
data ConstructorInfo

-- | Arity of the data constructor.
DataCon :: Arity -> ConstructorInfo
RecordCon :: PatternOrCopattern -> HasEta -> Arity -> [Dom QName] -> ConstructorInfo

-- | Return the number of non-parameter arguments to a constructor (arity).
--   In case of record constructors, also return the field names (plus
--   other info).
getConstructorInfo :: HasConstInfo m => QName -> m ConstructorInfo
getConstructorInfo' :: HasConstInfo m => QName -> m (Maybe ConstructorInfo)

-- | Check if a name refers to a datatype or a record with a named
--   constructor.
isDatatype :: QName -> TCM Bool

-- | Check if a name refers to a datatype or a record.
isDataOrRecordType :: QName -> TCM (Maybe DataOrRecord)

-- | Precodition: <a>Term</a> is <a>reduce</a>d.
isDataOrRecord :: Term -> TCM (Maybe (QName, DataOrRecord))
getNumberOfParameters :: HasConstInfo m => QName -> m (Maybe Nat)

-- | This is a simplified version of <tt>isDatatype</tt> from
--   <tt>Coverage</tt>, useful when we do not want to import the module.
getDatatypeArgs :: HasConstInfo m => Type -> m (Maybe (QName, Args, Args))
getNotErasedConstructors :: QName -> TCM [QName]

-- | Precondition: Name is a data or record type.
getConstructors :: QName -> TCM [QName]

-- | <a>Nothing</a> if not data or record type name.
getConstructors' :: QName -> TCM (Maybe [QName])

-- | <a>Nothing</a> if not data or record definition.
getConstructors_ :: Defn -> Maybe [QName]


-- | Various utility functions dealing with the non-linear, higher-order
--   patterns used for rewrite rules.
module Agda.TypeChecking.Rewriting.NonLinPattern

-- | Turn a term into a non-linear pattern, treating the free variables as
--   pattern variables. The first argument indicates the relevance we are
--   working under: if this is Irrelevant, then we construct a pattern that
--   never fails to match. The second argument is the number of bound
--   variables (from pattern lambdas). The third argument is the type of
--   the term.
class PatternFrom a b
patternFrom :: PatternFrom a b => Relevance -> Int -> TypeOf a -> a -> TCM b

-- | Convert from a non-linear pattern to a term.
class NLPatToTerm p a
nlPatToTerm :: (NLPatToTerm p a, PureTCM m) => p -> m a
nlPatToTerm :: (NLPatToTerm p a, NLPatToTerm p' a', Traversable f, p ~ f p', a ~ f a', PureTCM m) => p -> m a

-- | Gather the set of pattern variables of a non-linear pattern
class NLPatVars a
nlPatVarsUnder :: NLPatVars a => Int -> a -> IntSet
nlPatVars :: NLPatVars a => a -> IntSet

-- | Get all symbols that a non-linear pattern matches against
class GetMatchables a
getMatchables :: GetMatchables a => a -> [QName]
getMatchables :: (GetMatchables a, Foldable f, GetMatchables a', a ~ f a') => a -> [QName]
blockOnMetasIn :: (MonadBlock m, AllMetas t) => t -> m ()
assertPi :: Type -> TCM (Dom Type, Abs Type)
errNotPi :: Type -> TCM a
assertPath :: Type -> TCM (Sort, QName, Arg Term, Arg Term, Arg Term, Arg Term)
errNotPath :: Type -> TCM a
assertProjOf :: QName -> Type -> TCM (Dom Type, Abs Type)
errNotProjOf :: QName -> Type -> TCM a
assertConOf :: ConHead -> Type -> TCM Type
errNotConOf :: ConHead -> Type -> TCM a
instance Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables a => Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables [a]
instance Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables a => Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables a => Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables (Agda.Syntax.Internal.Dom a)
instance Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables a => Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables a => Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables (Agda.Syntax.Internal.Abs a)
instance (Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables a, Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables b) => Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables (a, b)
instance Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables Agda.TypeChecking.Monad.Base.NLPat
instance Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables Agda.TypeChecking.Monad.Base.NLPType
instance Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables Agda.TypeChecking.Monad.Base.NLPSort
instance Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Rewriting.NonLinPattern.GetMatchables Agda.TypeChecking.Monad.Base.RewriteRule
instance (Data.Foldable.Foldable f, Agda.TypeChecking.Rewriting.NonLinPattern.NLPatVars a) => Agda.TypeChecking.Rewriting.NonLinPattern.NLPatVars (f a)
instance Agda.TypeChecking.Rewriting.NonLinPattern.NLPatVars Agda.TypeChecking.Monad.Base.NLPType
instance Agda.TypeChecking.Rewriting.NonLinPattern.NLPatVars Agda.TypeChecking.Monad.Base.NLPSort
instance Agda.TypeChecking.Rewriting.NonLinPattern.NLPatVars Agda.TypeChecking.Monad.Base.NLPat
instance (Agda.TypeChecking.Rewriting.NonLinPattern.NLPatVars a, Agda.TypeChecking.Rewriting.NonLinPattern.NLPatVars b) => Agda.TypeChecking.Rewriting.NonLinPattern.NLPatVars (a, b)
instance Agda.TypeChecking.Rewriting.NonLinPattern.NLPatVars a => Agda.TypeChecking.Rewriting.NonLinPattern.NLPatVars (Agda.Syntax.Internal.Abs a)
instance Agda.TypeChecking.Rewriting.NonLinPattern.NLPatToTerm p a => Agda.TypeChecking.Rewriting.NonLinPattern.NLPatToTerm [p] [a]
instance Agda.TypeChecking.Rewriting.NonLinPattern.NLPatToTerm p a => Agda.TypeChecking.Rewriting.NonLinPattern.NLPatToTerm (Agda.Syntax.Common.Arg p) (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Rewriting.NonLinPattern.NLPatToTerm p a => Agda.TypeChecking.Rewriting.NonLinPattern.NLPatToTerm (Agda.Syntax.Internal.Dom p) (Agda.Syntax.Internal.Dom a)
instance Agda.TypeChecking.Rewriting.NonLinPattern.NLPatToTerm p a => Agda.TypeChecking.Rewriting.NonLinPattern.NLPatToTerm (Agda.Syntax.Internal.Elim.Elim' p) (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.TypeChecking.Rewriting.NonLinPattern.NLPatToTerm p a => Agda.TypeChecking.Rewriting.NonLinPattern.NLPatToTerm (Agda.Syntax.Internal.Abs p) (Agda.Syntax.Internal.Abs a)
instance Agda.TypeChecking.Rewriting.NonLinPattern.NLPatToTerm Agda.Syntax.Common.Nat Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Rewriting.NonLinPattern.NLPatToTerm Agda.TypeChecking.Monad.Base.NLPat Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Rewriting.NonLinPattern.NLPatToTerm Agda.TypeChecking.Monad.Base.NLPat Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Rewriting.NonLinPattern.NLPatToTerm Agda.TypeChecking.Monad.Base.NLPType Agda.Syntax.Internal.Type
instance Agda.TypeChecking.Rewriting.NonLinPattern.NLPatToTerm Agda.TypeChecking.Monad.Base.NLPSort Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Rewriting.NonLinPattern.PatternFrom a b => Agda.TypeChecking.Rewriting.NonLinPattern.PatternFrom (Agda.Syntax.Common.Arg a) (Agda.Syntax.Common.Arg b)
instance Agda.TypeChecking.Rewriting.NonLinPattern.PatternFrom Agda.Syntax.Internal.Elims [Agda.Syntax.Internal.Elim.Elim' Agda.TypeChecking.Monad.Base.NLPat]
instance Agda.TypeChecking.Rewriting.NonLinPattern.PatternFrom a b => Agda.TypeChecking.Rewriting.NonLinPattern.PatternFrom (Agda.Syntax.Internal.Dom a) (Agda.Syntax.Internal.Dom b)
instance Agda.TypeChecking.Rewriting.NonLinPattern.PatternFrom Agda.Syntax.Internal.Type Agda.TypeChecking.Monad.Base.NLPType
instance Agda.TypeChecking.Rewriting.NonLinPattern.PatternFrom Agda.Syntax.Internal.Sort Agda.TypeChecking.Monad.Base.NLPSort
instance Agda.TypeChecking.Rewriting.NonLinPattern.PatternFrom Agda.Syntax.Internal.Level Agda.TypeChecking.Monad.Base.NLPat
instance Agda.TypeChecking.Rewriting.NonLinPattern.PatternFrom Agda.Syntax.Internal.Term Agda.TypeChecking.Monad.Base.NLPat
instance Agda.TypeChecking.Free.Lazy.Free Agda.TypeChecking.Monad.Base.NLPat
instance Agda.TypeChecking.Free.Lazy.Free Agda.TypeChecking.Monad.Base.NLPType
instance Agda.TypeChecking.Free.Lazy.Free Agda.TypeChecking.Monad.Base.NLPSort


-- | Code which replaces pattern matching on record constructors with uses
--   of projection functions.
module Agda.TypeChecking.RecordPatterns

-- | Replaces pattern matching on record constructors with uses of
--   projection functions. Does not remove record constructor patterns
--   which have sub-patterns containing non-record constructor or literal
--   patterns.
translateRecordPatterns :: Clause -> TCM Clause
translateCompiledClauses :: forall m. (HasConstInfo m, MonadChange m) => CompiledClauses -> m CompiledClauses

-- | Split tree annotated for record pattern translation. type
--   RecordSplitTree = SplitTree' RecordSplitNode type RecordSplitTrees =
--   SplitTrees' RecordSplitNode
--   
--   Bottom-up procedure to record-pattern-translate split tree.
translateSplitTree :: SplitTree -> TCM SplitTree

-- | Take a record pattern <tt>p</tt> and yield a list of projections
--   corresponding to the pattern variables, from left to right.
--   
--   E.g. for <tt>(x , (y , z))</tt> we return <tt>[ fst, fst . snd, snd .
--   snd ]</tt>.
--   
--   If it is not a record pattern, error <a>ShouldBeRecordPattern</a> is
--   raised.
recordPatternToProjections :: DeBruijnPattern -> TCM [Term -> Term]
recordRHSToCopatterns :: forall m. (MonadChange m, PureTCM m) => Clause -> m [Clause]
instance Agda.TypeChecking.Monad.Base.MonadTCState Agda.TypeChecking.RecordPatterns.RecPatM
instance Agda.TypeChecking.Monad.Base.MonadTCEnv Agda.TypeChecking.RecordPatterns.RecPatM
instance Agda.Interaction.Options.HasOptions.HasOptions Agda.TypeChecking.RecordPatterns.RecPatM
instance Agda.TypeChecking.Monad.Base.MonadTCM Agda.TypeChecking.RecordPatterns.RecPatM
instance Control.Monad.IO.Class.MonadIO Agda.TypeChecking.RecordPatterns.RecPatM
instance GHC.Base.Monad Agda.TypeChecking.RecordPatterns.RecPatM
instance GHC.Base.Applicative Agda.TypeChecking.RecordPatterns.RecPatM
instance GHC.Base.Functor Agda.TypeChecking.RecordPatterns.RecPatM
instance GHC.Classes.Eq Agda.TypeChecking.RecordPatterns.Kind
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.RecordPatterns.Change
instance Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.RecordPatterns.Kind -> Agda.Syntax.Common.Nat)
instance Agda.TypeChecking.Pretty.PrettyTCM (Agda.TypeChecking.RecordPatterns.Kind -> Agda.Syntax.Common.Nat)
instance Agda.TypeChecking.RecordPatterns.DropFrom (Agda.TypeChecking.Coverage.SplitTree.SplitTree' c)
instance Agda.TypeChecking.RecordPatterns.DropFrom (c, Agda.TypeChecking.Coverage.SplitTree.SplitTree' c)
instance Agda.TypeChecking.RecordPatterns.DropFrom a => Agda.TypeChecking.RecordPatterns.DropFrom [a]


-- | Check that a datatype is strictly positive.
module Agda.TypeChecking.Positivity
type Graph n e = Graph n e

-- | Check that the datatypes in the mutual block containing the given
--   declarations are strictly positive.
--   
--   Also add information about positivity and recursivity of records to
--   the signature.
checkStrictlyPositive :: MutualInfo -> Set QName -> TCM ()
getDefArity :: Definition -> TCM Int
data Item
AnArg :: Nat -> Item
ADef :: QName -> Item
type Occurrences = Map Item [OccursWhere]

-- | Used to build <a>Occurrences</a> and occurrence graphs.
data OccurrencesBuilder
Concat :: [OccurrencesBuilder] -> OccurrencesBuilder
OccursAs :: Where -> OccurrencesBuilder -> OccurrencesBuilder
OccursHere :: Item -> OccurrencesBuilder

-- | <tt>OnlyVarsUpTo n occs</tt> discards occurrences of de Bruijn index
--   <tt>&gt;= n</tt>.
OnlyVarsUpTo :: Nat -> OccurrencesBuilder -> OccurrencesBuilder

-- | Used to build <a>Occurrences</a> and occurrence graphs.
data OccurrencesBuilder'
Concat' :: [OccurrencesBuilder'] -> OccurrencesBuilder'
OccursAs' :: Where -> OccurrencesBuilder' -> OccurrencesBuilder'
OccursHere' :: Item -> OccurrencesBuilder'

-- | Removes <a>OnlyVarsUpTo</a> entries.
preprocess :: OccurrencesBuilder -> OccurrencesBuilder'

-- | An interpreter for <a>OccurrencesBuilder</a>.
--   
--   WARNING: There can be lots of sharing between the generated
--   <a>OccursWhere</a> entries. Traversing all of these entries could be
--   expensive. (See <a>computeEdges</a> for an example.)
flatten :: OccurrencesBuilder -> Map Item Integer

-- | Context for computing occurrences.
data OccEnv
OccEnv :: [Maybe Item] -> Maybe QName -> OccEnv

-- | Items corresponding to the free variables.
--   
--   Potential invariant: It seems as if the list has the form
--   <tt><tt>genericReplicate</tt> n <a>Nothing</a> ++ <a>map</a>
--   (<a>Just</a> . <a>AnArg</a>) is</tt>, for some <tt>n</tt> and
--   <tt>is</tt>, where <tt>is</tt> is decreasing (non-strictly).
[vars] :: OccEnv -> [Maybe Item]

-- | Name for ∞ builtin.
[inf] :: OccEnv -> Maybe QName

-- | Monad for computing occurrences.
type OccM = Reader OccEnv
withExtendedOccEnv :: Maybe Item -> OccM a -> OccM a
withExtendedOccEnv' :: [Maybe Item] -> OccM a -> OccM a

-- | Running the monad
getOccurrences :: (Show a, PrettyTCM a, ComputeOccurrences a) => [Maybe Item] -> a -> TCM OccurrencesBuilder
class ComputeOccurrences a
occurrences :: ComputeOccurrences a => a -> OccM OccurrencesBuilder
occurrences :: (ComputeOccurrences a, Foldable t, ComputeOccurrences b, t b ~ a) => a -> OccM OccurrencesBuilder

-- | Computes the number of occurrences of different <a>Item</a>s in the
--   given definition.
--   
--   WARNING: There can be lots of sharing between the <a>OccursWhere</a>
--   entries. Traversing all of these entries could be expensive. (See
--   <a>computeEdges</a> for an example.)
computeOccurrences :: QName -> TCM (Map Item Integer)

-- | Computes the occurrences in the given definition.
computeOccurrences' :: QName -> TCM OccurrencesBuilder
data Node
DefNode :: !QName -> Node
ArgNode :: !QName -> !Nat -> Node

-- | Edge labels for the positivity graph.
data Edge a
Edge :: !Occurrence -> a -> Edge a

-- | Merges two edges between the same source and target.
mergeEdges :: Edge a -> Edge a -> Edge a

-- | WARNING: There can be lots of sharing between the <a>OccursWhere</a>
--   entries in the edges. Traversing all of these entries could be
--   expensive. (See <a>computeEdges</a> for an example.)
buildOccurrenceGraph :: Set QName -> TCM (Graph Node (Edge OccursWhere))

-- | Computes all non-<a>ozero</a> occurrence graph edges represented by
--   the given <a>OccurrencesBuilder</a>.
--   
--   WARNING: There can be lots of sharing between the <a>OccursWhere</a>
--   entries in the edges. Traversing all of these entries could be
--   expensive. For instance, for the function <tt>F</tt> in
--   <tt>benchmark<i>misc</i>SlowOccurrences.agda</tt> a large number of
--   edges from the argument <tt>X</tt> to the function <tt>F</tt> are
--   computed. These edges have polarity <a>StrictPos</a>, <a>JustNeg</a>
--   or <a>JustPos</a>, and contain the following <a>OccursWhere</a>
--   elements:
--   
--   <ul>
--   <li><tt><a>OccursWhere</a> _ <a>empty</a> (<a>fromList</a>
--   [<a>InDefOf</a> <a>F</a>, <a>InClause</a> 0])</tt>,</li>
--   <li><tt><a>OccursWhere</a> _ <a>empty</a> (<a>fromList</a>
--   [<a>InDefOf</a> <a>F</a>, <a>InClause</a> 0,
--   <a>LeftOfArrow</a>])</tt>,</li>
--   <li><tt><a>OccursWhere</a> _ <a>empty</a> (<a>fromList</a>
--   [<a>InDefOf</a> <a>F</a>, <a>InClause</a> 0, <a>LeftOfArrow</a>,
--   <a>LeftOfArrow</a>])</tt>,</li>
--   <li><tt><a>OccursWhere</a> _ <a>empty</a> (<a>fromList</a>
--   [<a>InDefOf</a> <a>F</a>, <a>InClause</a> 0, <a>LeftOfArrow</a>,
--   <a>LeftOfArrow</a>, <a>LeftOfArrow</a>])</tt>,</li>
--   <li>and so on.</li>
--   </ul>
computeEdges :: Set QName -> QName -> OccurrencesBuilder -> TCM [Edge Node (Edge OccursWhere)]
instance GHC.Show.Show Agda.TypeChecking.Positivity.Item
instance GHC.Classes.Ord Agda.TypeChecking.Positivity.Item
instance GHC.Classes.Eq Agda.TypeChecking.Positivity.Item
instance GHC.Classes.Ord Agda.TypeChecking.Positivity.Node
instance GHC.Classes.Eq Agda.TypeChecking.Positivity.Node
instance GHC.Base.Functor Agda.TypeChecking.Positivity.Edge
instance GHC.Show.Show a => GHC.Show.Show (Agda.TypeChecking.Positivity.Edge a)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.TypeChecking.Positivity.Edge a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.TypeChecking.Positivity.Edge a)
instance Agda.Utils.SemiRing.SemiRing (Agda.TypeChecking.Positivity.Edge (Data.Sequence.Internal.Seq Agda.TypeChecking.Positivity.Occurrence.OccursWhere))
instance Agda.TypeChecking.Pretty.PrettyTCMWithNode (Agda.TypeChecking.Positivity.Edge Agda.TypeChecking.Positivity.Occurrence.OccursWhere)
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Positivity.Node
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Positivity.Node
instance Agda.TypeChecking.Positivity.ComputeOccurrences Agda.Syntax.Internal.Clause
instance Agda.TypeChecking.Positivity.ComputeOccurrences Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Positivity.ComputeOccurrences Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Positivity.ComputeOccurrences Agda.Syntax.Internal.PlusLevel
instance Agda.TypeChecking.Positivity.ComputeOccurrences Agda.Syntax.Internal.Type
instance Agda.TypeChecking.Positivity.ComputeOccurrences a => Agda.TypeChecking.Positivity.ComputeOccurrences (Agda.Syntax.Internal.Tele a)
instance Agda.TypeChecking.Positivity.ComputeOccurrences a => Agda.TypeChecking.Positivity.ComputeOccurrences (Agda.Syntax.Internal.Abs a)
instance Agda.TypeChecking.Positivity.ComputeOccurrences a => Agda.TypeChecking.Positivity.ComputeOccurrences (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.TypeChecking.Positivity.ComputeOccurrences a => Agda.TypeChecking.Positivity.ComputeOccurrences (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Positivity.ComputeOccurrences a => Agda.TypeChecking.Positivity.ComputeOccurrences (Agda.Syntax.Internal.Dom a)
instance Agda.TypeChecking.Positivity.ComputeOccurrences a => Agda.TypeChecking.Positivity.ComputeOccurrences [a]
instance Agda.TypeChecking.Positivity.ComputeOccurrences a => Agda.TypeChecking.Positivity.ComputeOccurrences (GHC.Maybe.Maybe a)
instance (Agda.TypeChecking.Positivity.ComputeOccurrences a, Agda.TypeChecking.Positivity.ComputeOccurrences b) => Agda.TypeChecking.Positivity.ComputeOccurrences (a, b)
instance (GHC.Base.Semigroup a, GHC.Base.Monoid a) => GHC.Base.Monoid (Agda.TypeChecking.Positivity.OccM a)
instance GHC.Base.Semigroup Agda.TypeChecking.Positivity.OccurrencesBuilder
instance GHC.Base.Monoid Agda.TypeChecking.Positivity.OccurrencesBuilder
instance Agda.Syntax.Position.HasRange Agda.TypeChecking.Positivity.Item
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Positivity.Item
instance Agda.TypeChecking.Pretty.PrettyTCM (Data.Sequence.Internal.Seq Agda.TypeChecking.Positivity.Occurrence.OccursWhere)


-- | Dropping initial arguments (`<tt>parameters'</tt>) from a function
--   which can be easily reconstructed from its principal argument.
--   
--   A function which has such parameters is called ``projection-like''.
--   
--   The motivation for this optimization comes from the use of nested
--   records.
--   
--   First, let us look why proper projections need not store the
--   parameters: The type of a projection <tt>f</tt> is of the form <tt> f
--   : Γ → R Γ → C </tt> where <tt>R</tt> is the record type and <tt>C</tt>
--   is the type of the field <tt>f</tt>. Given a projection application
--   <tt> p pars u </tt> we know that the type of the principal argument
--   <tt>u</tt> is <tt> u : R pars </tt> thus, the parameters <tt>pars</tt>
--   are redundant in the projection application if we can always infer the
--   type of <tt>u</tt>. For projections, this is case, because the
--   principal argument <tt>u</tt> must be neutral; otherwise, if it was a
--   record value, we would have a redex, yet Agda maintains a β-normal
--   form.
--   
--   The situation for projections can be generalized to
--   ``projection-like'' functions <tt>f</tt>. Conditions:
--   
--   <ol>
--   <li>The type of <tt>f</tt> is of the form <tt>f : Γ → D Γ → ...</tt>
--   for some type constructor <tt>D</tt> which can never reduce.</li>
--   <li>For every reduced welltyped application <tt>f pars u ...</tt>, the
--   type of <tt>u</tt> is inferable.</li>
--   </ol>
--   
--   This then allows <tt>pars</tt> to be dropped always.
--   
--   Condition 2 is approximated by a bunch of criteria, for details see
--   function <a>makeProjection</a>.
--   
--   Typical projection-like functions are compositions of projections
--   which arise from nested records.
--   
--   Notes:
--   
--   <ol>
--   <li>This analysis could be dualized to ``constructor-like'' functions
--   whose parameters are reconstructable from the target type. But such
--   functions would need to be fully applied.</li>
--   <li>A more general analysis of which arguments are reconstructible can
--   be found inJason C. Reed, Redundancy elimination for LF LFTMP
--   2004.</li>
--   </ol>
module Agda.TypeChecking.ProjectionLike

-- | View for a <tt>Def f (Apply a : es)</tt> where
--   <tt>isRelevantProjection f</tt>. Used for projection-like <tt>f</tt>s.
data ProjectionView

-- | A projection or projection-like function, applied to its principal
--   argument
ProjectionView :: QName -> Arg Term -> Elims -> ProjectionView
[projViewProj] :: ProjectionView -> QName
[projViewSelf] :: ProjectionView -> Arg Term
[projViewSpine] :: ProjectionView -> Elims

-- | Just a lone projection-like function, missing its principal argument
--   (from which we could infer the parameters).
LoneProjectionLike :: QName -> ArgInfo -> ProjectionView

-- | Not a projection or projection-like thing.
NoProjection :: Term -> ProjectionView

-- | Semantics of <a>ProjectionView</a>.
unProjView :: ProjectionView -> Term

-- | Top-level <a>ProjectionView</a> (no reduction).
projView :: HasConstInfo m => Term -> m ProjectionView

-- | Reduce away top-level projection like functions. (Also reduces
--   projections, but they should not be there, since Internal is in
--   lambda- and projection-beta-normal form.)
reduceProjectionLike :: PureTCM m => Term -> m Term
data ProjEliminator
EvenLone :: ProjEliminator
ButLone :: ProjEliminator
NoPostfix :: ProjEliminator

-- | Turn prefix projection-like function application into postfix ones.
--   This does just one layer, such that the top spine contains the
--   projection-like functions as projections. Used in
--   <tt>compareElims</tt> in <tt>TypeChecking.Conversion</tt> and in
--   <a>Agda.TypeChecking.CheckInternal</a>.
--   
--   If the <a>Bool</a> is <a>True</a>, a lone projection like function
--   will be turned into a lambda-abstraction, expecting the principal
--   argument. If the <a>Bool</a> is <a>False</a>, it will be returned
--   unaltered.
--   
--   No precondition. Preserves constructorForm, since it really does only
--   something on (applications of) projection-like functions.
elimView :: PureTCM m => ProjEliminator -> Term -> m Term

-- | Which <tt>Def</tt>types are eligible for the principle argument of a
--   projection-like function?
eligibleForProjectionLike :: HasConstInfo m => QName -> m Bool

-- | Turn a definition into a projection if it looks like a projection.
--   
--   Conditions for projection-likeness of <tt>f</tt>:
--   
--   <ol>
--   <li>The type of <tt>f</tt> must be of the shape <tt>Γ → D Γ → C</tt>
--   for <tt>D</tt> a name (<tt>Def</tt>) which is
--   <a>eligibleForProjectionLike</a>: <tt>data</tt> <i> <tt>record</tt>
--   </i> <tt>postulate</tt>.</li>
--   <li>The application of f should only get stuck if the principal
--   argument is inferable (neutral). Thus:</li>
--   </ol>
--   
--   a. <tt>f</tt> cannot have absurd clauses (which are stuck even if the
--   principal argument is a constructor).
--   
--   b. <tt>f</tt> cannot be abstract as it does not reduce outside
--   abstract blocks (always stuck).
--   
--   c. <tt>f</tt> cannot match on other arguments than the principal
--   argument.
--   
--   d. <tt>f</tt> cannot match deeply.
--   
--   e. <tt>f</tt>s body may not mention the parameters.
--   
--   f. A rhs of <tt>f</tt> cannot be a record expression, since this will
--   be translated to copatterns by recordExpressionsToCopatterns. Thus, an
--   application of <tt>f</tt> waiting for a projection can be stuck even
--   when the principal argument is a constructor.
--   
--   g. <tt>f</tt> cannot be an irrelevant definition (Andreas, 2022-03-07,
--   #5809), as those are not reduced.
--   
--   For internal reasons:
--   
--   <ol>
--   <li><tt>f</tt> cannot be constructor headed</li>
--   <li><tt>f</tt> cannot be recursive, since we have not implemented a
--   function which goes through the bodies of the <tt>f</tt> and the
--   mutually recursive functions and drops the parameters from all
--   applications of <tt>f</tt>.</li>
--   </ol>
--   
--   Examples for these reasons: see
--   test<i>Succeed</i>NotProjectionLike.agda
makeProjection :: QName -> TCM ()

-- | Infer type of a neutral term. See also <tt>infer</tt> in
--   <tt>Agda.TypeChecking.CheckInternal</tt>, which has a very similar
--   logic but also type checks all arguments.
inferNeutral :: (PureTCM m, MonadBlock m) => Term -> m Type

-- | Compute the head type of a Def application. For projection-like
--   functions this requires inferring the type of the principal argument.
computeDefType :: (PureTCM m, MonadBlock m) => QName -> Elims -> m Type
instance GHC.Classes.Eq Agda.TypeChecking.ProjectionLike.ProjEliminator


-- | This module contains the rules for Agda's sort system viewed as a pure
--   type system (pts). The specification of a pts consists of a set of
--   axioms of the form <tt>s1 : s2</tt> specifying when a sort fits in
--   another sort, and a set of rules of the form <tt>(s1,s2,s3)</tt>
--   specifying that a pi type with domain in <tt>s1</tt> and codomain in
--   <tt>s2</tt> itself fits into sort <tt>s3</tt>.
--   
--   To ensure unique principal types, the axioms and rules of Agda's pts
--   are given by two partial functions <tt>univSort'</tt> and
--   <tt>piSort'</tt> (see <tt>Agda.TypeChecking.Substitute</tt>). If these
--   functions return <tt>Nothing</tt>, a constraint is added to ensure
--   that the sort will be computed eventually.
--   
--   One <tt>upgrade</tt> over the standard definition of a pts is that in
--   a rule <tt>(s1,s2,s3)</tt>, in Agda the sort <tt>s2</tt> can depend on
--   a variable of some type in <tt>s1</tt>. This is needed to support
--   Agda's universe polymorphism where we can have e.g. a function of type
--   <tt>∀ {ℓ} → Set ℓ</tt>.
module Agda.TypeChecking.Sort

-- | Infer the sort of another sort. If we can compute the bigger sort
--   straight away, return that. Otherwise, return <tt>UnivSort s</tt> and
--   add a constraint to ensure we can compute the sort eventually.
inferUnivSort :: (PureTCM m, MonadConstraint m) => Sort -> m Sort
sortFitsIn :: MonadConversion m => Sort -> Sort -> m ()
hasBiggerSort :: Sort -> TCM ()

-- | Infer the sort of a Pi type. If we can compute the sort straight away,
--   return that. Otherwise, return a <a>PiSort</a> and add a constraint to
--   ensure we can compute the sort eventually.
inferPiSort :: (PureTCM m, MonadConstraint m) => Dom Type -> Abs Sort -> m Sort

-- | As <tt>inferPiSort</tt>, but for a nondependent function type.
inferFunSort :: (PureTCM m, MonadConstraint m) => Dom Type -> Sort -> m Sort

-- | <tt>hasPTSRule a x.s</tt> checks that we can form a Pi-type <tt>(x :
--   a) -&gt; b</tt> where <tt>b : s</tt>.
hasPTSRule :: Dom Type -> Abs Sort -> TCM ()

-- | Recursively check that an iterated function type constructed by
--   <tt>telePi</tt> is well-sorted.
checkTelePiSort :: Type -> TCM ()
ifIsSort :: (MonadReduce m, MonadBlock m) => Type -> (Sort -> m a) -> m a -> m a
ifNotSort :: (MonadReduce m, MonadBlock m) => Type -> m a -> (Sort -> m a) -> m a

-- | Result is in reduced form.
shouldBeSort :: (PureTCM m, MonadBlock m, MonadError TCErr m) => Type -> m Sort

-- | Reconstruct the sort of a term.
--   
--   Precondition: given term is a well-sorted type.
sortOf :: forall m. (PureTCM m, MonadBlock m, MonadConstraint m) => Term -> m Sort

-- | Reconstruct the minimal sort of a type (ignoring the sort annotation).
sortOfType :: forall m. (PureTCM m, MonadBlock m, MonadConstraint m) => Type -> m Sort

module Agda.TypeChecking.Pretty.Warning

-- | Prefix for a warning text showing name of the warning. E.g.
--   <tt>warning: -W[no]<a>warning_name</a></tt>
prettyWarningName :: MonadPretty m => WarningName -> m Doc
prettyWarning :: MonadPretty m => Warning -> m Doc
prettyRecordFieldWarning :: MonadPretty m => RecordFieldWarning -> m Doc
prettyDuplicateFields :: MonadPretty m => [Name] -> m Doc
prettyTooManyFields :: MonadPretty m => QName -> [Name] -> [Name] -> m Doc

-- | Report a number of names that are not in scope.
prettyNotInScopeNames :: (MonadPretty m, Pretty a, HasRange a) => Bool -> (a -> m Doc) -> [a] -> m Doc

-- | Suggest some corrections to a misspelled name.
didYouMean :: (MonadPretty m, Pretty a, Pretty b) => [QName] -> (a -> b) -> a -> Maybe (m Doc)
prettyTCWarnings :: [TCWarning] -> TCM String
prettyTCWarnings' :: [TCWarning] -> TCM [Doc]

-- | If there are several warnings, remove the unsolved-constraints warning
--   in case there are no interesting constraints to list.
filterTCWarnings :: [TCWarning] -> [TCWarning]

-- | Turns warnings, if any, into errors.
tcWarningsToError :: [TCWarning] -> TCM ()

-- | Depending which flags are set, one may happily ignore some warnings.
applyFlagsToTCWarningsPreserving :: HasOptions m => Set WarningName -> [TCWarning] -> m [TCWarning]
applyFlagsToTCWarnings :: HasOptions m => [TCWarning] -> m [TCWarning]
isBoundaryConstraint :: (ReadTCState m, MonadTCM m) => ProblemConstraint -> m (Maybe Range)
getAllUnsolvedWarnings :: (MonadFail m, ReadTCState m, MonadWarning m, MonadTCM m) => m [TCWarning]

-- | Collect all warnings that have accumulated in the state.
getAllWarnings :: (MonadFail m, ReadTCState m, MonadWarning m, MonadTCM m) => WhichWarnings -> m [TCWarning]
getAllWarningsPreserving :: (MonadFail m, ReadTCState m, MonadWarning m, MonadTCM m) => Set WarningName -> WhichWarnings -> m [TCWarning]
getAllWarningsOfTCErr :: TCErr -> TCM [TCWarning]
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.TCWarning


-- | A constructor argument is forced if it appears as pattern variable in
--   an index of the target.
--   
--   For instance <tt>x</tt> is forced in <tt>sing</tt> and <tt>n</tt> is
--   forced in <tt>zero</tt> and <tt>suc</tt>:
--   
--   <pre>
--   data Sing {a}{A : Set a} : A -&gt; Set where
--     sing : (x : A) -&gt; Sing x
--   
--   data Fin : Nat -&gt; Set where
--     zero : (n : Nat) -&gt; Fin (suc n)
--     suc  : (n : Nat) (i : Fin n) -&gt; Fin (suc n)
--   </pre>
--   
--   At runtime, forced constructor arguments may be erased as they can be
--   recovered from dot patterns. For instance, <tt> unsing : {A : Set} (x
--   : A) -&gt; Sing x -&gt; A unsing .x (sing x) = x </tt> can become <tt>
--   unsing x sing = x </tt> and <tt> proj : (n : Nat) (i : Fin n) -&gt;
--   Nat proj .(suc n) (zero n) = n proj .(suc n) (suc n i) = n </tt>
--   becomes <tt> proj (suc n) zero = n proj (suc n) (suc i) = n </tt>
--   
--   This module implements the analysis of which constructor arguments are
--   forced. The process of moving the binding site of forced arguments is
--   implemented in the unifier (see the Solution step of
--   Agda.TypeChecking.Rules.LHS.Unify.unifyStep).
--   
--   Forcing is a concept from pattern matching and thus builds on the
--   concept of equality (I) used there (closed terms, extensional) which
--   is different from the equality (II) used in conversion checking and
--   the constraint solver (open terms, intensional).
--   
--   Up to issue 1441 (Feb 2015), the forcing analysis here relied on the
--   wrong equality (II), considering type constructors as injective. This
--   is unsound for program extraction, but ok if forcing is only used to
--   decide which arguments to skip during conversion checking.
--   
--   From now on, forcing uses equality (I) and does not search for forced
--   variables under type constructors. This may lose some savings during
--   conversion checking. If this turns out to be a problem, the old
--   forcing could be brought back, using a new modality <tt>Skip</tt> to
--   indicate that this is a relevant argument but still can be skipped
--   during conversion checking as it is forced by equality (II).
module Agda.TypeChecking.Forcing

-- | Given the type of a constructor (excluding the parameters), decide
--   which arguments are forced.
computeForcingAnnotations :: QName -> Type -> TCM [IsForced]
isForced :: IsForced -> Bool
nextIsForced :: [IsForced] -> (IsForced, [IsForced])
instance Agda.TypeChecking.Monad.Base.MonadReduce Agda.TypeChecking.Forcing.ForcedVariableCollection'
instance Agda.TypeChecking.Monad.Base.ReadTCState Agda.TypeChecking.Forcing.ForcedVariableCollection'
instance Agda.TypeChecking.Monad.Signature.HasConstInfo Agda.TypeChecking.Forcing.ForcedVariableCollection'
instance Agda.Interaction.Options.HasOptions.HasOptions Agda.TypeChecking.Forcing.ForcedVariableCollection'
instance Agda.TypeChecking.Monad.Base.MonadTCEnv Agda.TypeChecking.Forcing.ForcedVariableCollection'
instance Agda.TypeChecking.Monad.Debug.MonadDebug Agda.TypeChecking.Forcing.ForcedVariableCollection'
instance Control.Monad.Fail.MonadFail Agda.TypeChecking.Forcing.ForcedVariableCollection'
instance Control.Monad.State.Class.MonadState Agda.TypeChecking.Forcing.ForcedVariableState Agda.TypeChecking.Forcing.ForcedVariableCollection'
instance Control.Monad.Reader.Class.MonadReader Agda.TypeChecking.Forcing.ForcedVariableContext Agda.TypeChecking.Forcing.ForcedVariableCollection'
instance GHC.Base.Monad Agda.TypeChecking.Forcing.ForcedVariableCollection'
instance GHC.Base.Applicative Agda.TypeChecking.Forcing.ForcedVariableCollection'
instance GHC.Base.Functor Agda.TypeChecking.Forcing.ForcedVariableCollection'
instance Agda.TypeChecking.Forcing.ForcedVariables a => Agda.TypeChecking.Forcing.ForcedVariables [a]
instance Agda.TypeChecking.Forcing.ForcedVariables a => Agda.TypeChecking.Forcing.ForcedVariables (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.TypeChecking.Forcing.ForcedVariables a => Agda.TypeChecking.Forcing.ForcedVariables (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Forcing.ForcedVariables Agda.Syntax.Internal.Term
instance GHC.Base.Semigroup Agda.TypeChecking.Forcing.ForcedVariableCollection
instance GHC.Base.Monoid Agda.TypeChecking.Forcing.ForcedVariableCollection
instance Agda.Utils.Singleton.Singleton (Agda.Syntax.Common.Nat, Agda.Syntax.Common.Modality) Agda.TypeChecking.Forcing.ForcedVariableCollection


-- | Given
--   
--   <ol>
--   <li>the function clauses <tt>cs</tt></li>
--   <li>the patterns <tt>ps</tt> of the split clause</li>
--   </ol>
--   
--   we want to compute a variable index (in the split clause) to split on
--   next.
--   
--   The matcher here checks whether the split clause is covered by one of
--   the given clauses <tt>cs</tt> or whether further splitting is needed
--   (and when yes, where).
module Agda.TypeChecking.Coverage.Match

-- | If matching is inconclusive (<tt>Block</tt>) we want to know which
--   variables or projections are blocking the match.
data Match a

-- | Matches unconditionally.
Yes :: a -> Match a

-- | Definitely does not match.
No :: Match a
Block :: BlockedOnResult -> BlockingVars -> Match a

-- | <tt>BlockedOnProj o</tt> if the clause has a result split.
[blockedOnResult] :: Match a -> BlockedOnResult

-- | <tt>BlockingVar i cs ls o</tt> means variable <tt>i</tt> is blocked on
--   constructors <tt>cs</tt> and literals <tt>ls</tt>.
[blockedOnVars] :: Match a -> BlockingVars

-- | Match the given patterns against a list of clauses.
--   
--   If successful, return the index of the covering clause.
match :: PureTCM m => [Clause] -> [NamedArg SplitPattern] -> m (Match (Nat, SplitInstantiation))
matchClause :: PureTCM m => [NamedArg SplitPattern] -> Clause -> m MatchResult
type SplitPattern = Pattern' SplitPatVar

-- | For each variable in the patterns of a split clause, we remember the
--   de Bruijn-index and the literals excluded by previous matches.
data SplitPatVar
SplitPatVar :: PatVarName -> Int -> [Literal] -> SplitPatVar
[splitPatVarName] :: SplitPatVar -> PatVarName
[splitPatVarIndex] :: SplitPatVar -> Int
[splitExcludedLits] :: SplitPatVar -> [Literal]
fromSplitPattern :: NamedArg SplitPattern -> NamedArg DeBruijnPattern
fromSplitPatterns :: [NamedArg SplitPattern] -> [NamedArg DeBruijnPattern]
toSplitPatterns :: [NamedArg DeBruijnPattern] -> [NamedArg SplitPattern]
toSplitPSubst :: PatternSubstitution -> SplitPSubstitution
applySplitPSubst :: TermSubst a => SplitPSubstitution -> a -> a

-- | A pattern that matches anything (modulo eta).
isTrivialPattern :: HasConstInfo m => Pattern' a -> m Bool

-- | Variable blocking a match.
data BlockingVar
BlockingVar :: Nat -> [ConHead] -> [Literal] -> Bool -> Bool -> BlockingVar

-- | De Bruijn index of variable blocking the match.
[blockingVarNo] :: BlockingVar -> Nat

-- | Constructors in this position.
[blockingVarCons] :: BlockingVar -> [ConHead]

-- | Literals in this position.
[blockingVarLits] :: BlockingVar -> [Literal]

-- | True if at least one clause has a variable pattern in this position.
[blockingVarOverlap] :: BlockingVar -> Bool

-- | True if at least one clause has a lazy pattern in this position.
[blockingVarLazy] :: BlockingVar -> Bool
type BlockingVars = [BlockingVar]

-- | Missing elimination blocking a match.
data BlockedOnResult

-- | Blocked on unsplit projection.
BlockedOnProj :: Bool -> BlockedOnResult

-- | True if there are also matching clauses without an unsplit copattern.
[blockedOnResultOverlap] :: BlockedOnResult -> Bool

-- | Blocked on unintroduced argument.
BlockedOnApply :: ApplyOrIApply -> BlockedOnResult

-- | Is the unintroduced argument an <a>IApply</a> pattern?
[blockedOnResultIApply] :: BlockedOnResult -> ApplyOrIApply
NotBlockedOnResult :: BlockedOnResult
setBlockingVarOverlap :: BlockingVar -> BlockingVar
data ApplyOrIApply
IsApply :: ApplyOrIApply
IsIApply :: ApplyOrIApply
instance GHC.Show.Show Agda.TypeChecking.Coverage.Match.BlockingVar
instance GHC.Base.Functor Agda.TypeChecking.Coverage.Match.Match
instance GHC.Show.Show Agda.TypeChecking.Coverage.Match.SplitPatVar
instance Agda.TypeChecking.Substitute.Class.Subst Agda.TypeChecking.Coverage.Match.SplitPattern
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Coverage.Match.SplitPatVar
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Coverage.Match.SplitPatVar
instance Agda.TypeChecking.Substitute.DeBruijn.DeBruijn Agda.TypeChecking.Coverage.Match.SplitPatVar
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Coverage.Match.BlockingVar

module Agda.TypeChecking.Conversion.Pure
data FreshThings
FreshThings :: Int -> ProblemId -> NameId -> FreshThings
[freshInt] :: FreshThings -> Int
[freshProblemId] :: FreshThings -> ProblemId
[freshNameId] :: FreshThings -> NameId
newtype PureConversionT m a
PureConversionT :: ExceptT TCErr (StateT FreshThings m) a -> PureConversionT m a
[unPureConversionT] :: PureConversionT m a -> ExceptT TCErr (StateT FreshThings m) a
pureEqualTerm :: (PureTCM m, MonadBlock m) => Type -> Term -> Term -> m Bool
pureEqualType :: (PureTCM m, MonadBlock m) => Type -> Type -> m Bool
pureCompareAs :: (PureTCM m, MonadBlock m) => Comparison -> CompareAs -> Term -> Term -> m Bool
runPureConversion :: (MonadBlock m, PureTCM m) => PureConversionT m a -> m (Maybe a)
instance (Agda.TypeChecking.Monad.Builtin.HasBuiltins m, Agda.TypeChecking.Monad.Signature.HasConstInfo m, Agda.TypeChecking.Monad.Context.MonadAddContext m, Agda.TypeChecking.Monad.Base.MonadReduce m) => Agda.TypeChecking.Monad.Pure.PureTCM (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance GHC.Base.Monad m => Control.Monad.State.Class.MonadState Agda.TypeChecking.Conversion.Pure.FreshThings (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance GHC.Base.Monad m => Control.Monad.Error.Class.MonadError Agda.TypeChecking.Monad.Base.TCErr (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance GHC.Base.Monad m => GHC.Base.Monad (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance GHC.Base.Monad m => GHC.Base.Applicative (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance GHC.Base.Functor m => GHC.Base.Functor (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance Control.Monad.Fail.MonadFail m => Control.Monad.Fail.MonadFail (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance Agda.TypeChecking.Monad.Builtin.HasBuiltins m => Agda.TypeChecking.Monad.Builtin.HasBuiltins (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance Agda.TypeChecking.Monad.Signature.HasConstInfo m => Agda.TypeChecking.Monad.Signature.HasConstInfo (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance Agda.Interaction.Options.HasOptions.HasOptions m => Agda.Interaction.Options.HasOptions.HasOptions (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance Agda.TypeChecking.Monad.Base.MonadTCEnv m => Agda.TypeChecking.Monad.Base.MonadTCEnv (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance Agda.TypeChecking.Monad.Base.ReadTCState m => Agda.TypeChecking.Monad.Base.ReadTCState (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance Agda.TypeChecking.Monad.Base.MonadReduce m => Agda.TypeChecking.Monad.Base.MonadReduce (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance Agda.TypeChecking.Monad.Context.MonadAddContext m => Agda.TypeChecking.Monad.Context.MonadAddContext (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance Agda.TypeChecking.Monad.Debug.MonadDebug m => Agda.TypeChecking.Monad.Debug.MonadDebug (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance Control.Monad.Trans.Class.MonadTrans Agda.TypeChecking.Conversion.Pure.PureConversionT
instance (GHC.Base.Monad m, GHC.Base.Semigroup a) => GHC.Base.Semigroup (Agda.TypeChecking.Conversion.Pure.PureConversionT m a)
instance (Data.String.IsString a, GHC.Base.Monad m) => Data.String.IsString (Agda.TypeChecking.Conversion.Pure.PureConversionT m a)
instance GHC.Base.Monad m => Agda.Utils.Null.Null (Agda.TypeChecking.Conversion.Pure.PureConversionT m Agda.TypeChecking.Pretty.Doc)
instance GHC.Base.Monad m => Agda.TypeChecking.Monad.Base.MonadBlock (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance (Agda.TypeChecking.Monad.Pure.PureTCM m, Agda.TypeChecking.Monad.Base.MonadBlock m) => Agda.TypeChecking.Monad.Constraints.MonadConstraint (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance (Agda.TypeChecking.Monad.Pure.PureTCM m, Agda.TypeChecking.Monad.Base.MonadBlock m) => Agda.TypeChecking.Monad.MetaVars.MonadMetaSolver (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance (Agda.TypeChecking.Monad.Pure.PureTCM m, Agda.TypeChecking.Monad.Base.MonadBlock m) => Agda.TypeChecking.Monad.MetaVars.MonadInteractionPoints (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance Agda.TypeChecking.Monad.Base.ReadTCState m => Agda.TypeChecking.Monad.Base.MonadStConcreteNames (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance (Agda.TypeChecking.Monad.Pure.PureTCM m, Agda.TypeChecking.Monad.Base.MonadBlock m) => Agda.TypeChecking.Warnings.MonadWarning (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance Agda.TypeChecking.Monad.Base.ReadTCState m => Agda.TypeChecking.Monad.Statistics.MonadStatistics (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance GHC.Base.Monad m => Agda.TypeChecking.Monad.Base.MonadFresh Agda.Syntax.Common.ProblemId (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance GHC.Base.Monad m => Agda.TypeChecking.Monad.Base.MonadFresh Agda.Syntax.Common.NameId (Agda.TypeChecking.Conversion.Pure.PureConversionT m)
instance GHC.Base.Monad m => Agda.TypeChecking.Monad.Base.MonadFresh GHC.Types.Int (Agda.TypeChecking.Conversion.Pure.PureConversionT m)


-- | Non-linear matching of the lhs of a rewrite rule against a neutral
--   term.
--   
--   Given a lhs
--   
--   Δ ⊢ lhs : B
--   
--   and a candidate term
--   
--   Γ ⊢ t : A
--   
--   we seek a substitution Γ ⊢ σ : Δ such that
--   
--   Γ ⊢ B[σ] = A and Γ ⊢ lhs[σ] = t : A
module Agda.TypeChecking.Rewriting.NonLinMatch

-- | Monad for non-linear matching.
newtype NLM a
NLM :: ExceptT Blocked_ (StateT NLMState ReduceM) a -> NLM a
[unNLM] :: NLM a -> ExceptT Blocked_ (StateT NLMState ReduceM) a
data NLMState
NLMState :: Sub -> PostponedEquations -> NLMState
[_nlmSub] :: NLMState -> Sub
[_nlmEqs] :: NLMState -> PostponedEquations
nlmSub :: Lens' NLMState Sub
nlmEqs :: Lens' NLMState PostponedEquations
runNLM :: MonadReduce m => NLM () -> m (Either Blocked_ NLMState)
matchingBlocked :: Blocked_ -> NLM ()

-- | Add substitution <tt>i |-&gt; v : a</tt> to result of matching.
tellSub :: Relevance -> Int -> Type -> Term -> NLM ()
tellEq :: Telescope -> Context -> Type -> Term -> Term -> NLM ()
type Sub = IntMap (Relevance, Term)

-- | Matching against a term produces a constraint which we have to verify
--   after applying the substitution computed by matching.
data PostponedEquation
PostponedEquation :: Context -> Type -> Term -> Term -> PostponedEquation

-- | Context of free variables in the equation
[eqFreeVars] :: PostponedEquation -> Context

-- | Type of the equation, living in same context as the rhs.
[eqType] :: PostponedEquation -> Type

-- | Term from pattern, living in pattern context.
[eqLhs] :: PostponedEquation -> Term

-- | Term from scrutinee, living in context where matching was invoked.
[eqRhs] :: PostponedEquation -> Term
type PostponedEquations = [PostponedEquation]

-- | Match a non-linear pattern against a neutral term, returning a
--   substitution.
class Match a b
match :: Match a b => Relevance -> Telescope -> Context -> TypeOf b -> a -> b -> NLM ()
extendContext :: MonadAddContext m => Context -> ArgName -> Dom Type -> m Context
makeSubstitution :: Telescope -> Sub -> Maybe Substitution
checkPostponedEquations :: PureTCM m => Substitution -> PostponedEquations -> m (Maybe Blocked_)
nonLinMatch :: (PureTCM m, Match a b) => Telescope -> TypeOf b -> a -> b -> m (Either Blocked_ Substitution)

-- | Typed βη-equality, also handles empty record types. Returns
--   <a>Nothing</a> if the terms are equal, or `Just b` if the terms are
--   not (where b contains information about possible metas blocking the
--   comparison)
equal :: PureTCM m => Type -> Term -> Term -> m (Maybe Blocked_)

-- | Utility function for getting the name and type of a head term (i.e. a
--   <a>Def</a> or <a>Con</a> with no arguments)
getTypedHead :: PureTCM m => Term -> m (Maybe (QName, Type))
instance Agda.TypeChecking.Monad.Pure.PureTCM Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance Agda.TypeChecking.Monad.Debug.MonadDebug Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance Agda.TypeChecking.Monad.Context.MonadAddContext Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance Agda.TypeChecking.Monad.Base.MonadReduce Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance Agda.TypeChecking.Monad.Base.MonadTCEnv Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance Agda.TypeChecking.Monad.Base.ReadTCState Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance Agda.Interaction.Options.HasOptions.HasOptions Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance Agda.TypeChecking.Monad.Signature.HasConstInfo Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance Agda.TypeChecking.Monad.Builtin.HasBuiltins Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance Control.Monad.State.Class.MonadState Agda.TypeChecking.Rewriting.NonLinMatch.NLMState Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance Control.Monad.Error.Class.MonadError Agda.Syntax.Internal.Blocked_ Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance GHC.Base.MonadPlus Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance GHC.Base.Alternative Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance Control.Monad.Fail.MonadFail Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance GHC.Base.Monad Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance GHC.Base.Applicative Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance GHC.Base.Functor Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance Agda.TypeChecking.Rewriting.NonLinMatch.Match a b => Agda.TypeChecking.Rewriting.NonLinMatch.Match (Agda.Syntax.Common.Arg a) (Agda.Syntax.Common.Arg b)
instance Agda.TypeChecking.Rewriting.NonLinMatch.Match [Agda.Syntax.Internal.Elim.Elim' Agda.TypeChecking.Monad.Base.NLPat] Agda.Syntax.Internal.Elims
instance Agda.TypeChecking.Rewriting.NonLinMatch.Match a b => Agda.TypeChecking.Rewriting.NonLinMatch.Match (Agda.Syntax.Internal.Dom a) (Agda.Syntax.Internal.Dom b)
instance Agda.TypeChecking.Rewriting.NonLinMatch.Match Agda.TypeChecking.Monad.Base.NLPType Agda.Syntax.Internal.Type
instance Agda.TypeChecking.Rewriting.NonLinMatch.Match Agda.TypeChecking.Monad.Base.NLPSort Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Rewriting.NonLinMatch.Match Agda.TypeChecking.Monad.Base.NLPat Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Rewriting.NonLinMatch.Match Agda.TypeChecking.Monad.Base.NLPat Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Monad.Base.MonadBlock Agda.TypeChecking.Rewriting.NonLinMatch.NLM
instance Agda.Utils.Null.Null Agda.TypeChecking.Rewriting.NonLinMatch.NLMState


-- | The monad for the termination checker.
--   
--   The termination monad <tt>TerM</tt> is an extension of the type
--   checking monad <a>TCMT</a> by an environment with information needed
--   by the termination checker.
module Agda.Termination.Monad

-- | The target of the function we are checking.
data Target

-- | The target of recursion is a <tt>record</tt>, <tt>data</tt>, or
--   unreducible <tt>Def</tt>.
TargetDef :: QName -> Target

-- | We are termination-checking a record.
TargetRecord :: Target

-- | None of the above two or unknown.
TargetOther :: Target

-- | The current guardedness level.
type Guarded = Order

-- | The termination environment.
data TerEnv
TerEnv :: Bool -> Maybe QName -> Maybe QName -> CutOff -> QName -> MutualNames -> Set QName -> Bool -> Target -> [Bool] -> Bool -> Int -> MaskedDeBruijnPatterns -> !Int -> !Guarded -> Bool -> VarSet -> TerEnv

-- | Are we mining dot patterns to find evindence of structal descent?
[terUseDotPatterns] :: TerEnv -> Bool

-- | The name of size successor, if any.
[terSizeSuc] :: TerEnv -> Maybe QName

-- | The name of the delay constructor (sharp), if any.
[terSharp] :: TerEnv -> Maybe QName

-- | Depth at which to cut off the structural order.
[terCutOff] :: TerEnv -> CutOff

-- | The name of the function we are currently checking.
[terCurrent] :: TerEnv -> QName

-- | The names of the functions in the mutual block we are checking. This
--   includes the internally generated functions (with, extendedlambda,
--   coinduction).
[terMutual] :: TerEnv -> MutualNames

-- | The list of name actually appearing in the file (abstract syntax).
--   Excludes the internally generated functions.
[terUserNames] :: TerEnv -> Set QName

-- | Does the actual clause result from with-inlining? (If yes, it may be
--   ill-typed.)
[terHaveInlinedWith] :: TerEnv -> Bool

-- | Target type of the function we are currently termination checking.
--   Only the constructors of <a>Target</a> are considered guarding.
[terTarget] :: TerEnv -> Target

-- | Only consider the <a>notMasked</a> <a>False</a> arguments for
--   establishing termination. See issue #1023.
[terMaskArgs] :: TerEnv -> [Bool]

-- | Only consider guardedness if <a>False</a> (not masked).
[terMaskResult] :: TerEnv -> Bool

-- | How many <tt>SIZELT</tt> relations do we have in the context (= clause
--   telescope). Used to approximate termination for metas in call args.
[_terSizeDepth] :: TerEnv -> Int

-- | The patterns of the clause we are checking.
[terPatterns] :: TerEnv -> MaskedDeBruijnPatterns

-- | Number of additional binders we have gone under (and consequently need
--   to raise the patterns to compare to terms). Updated during call graph
--   extraction, hence strict.
[terPatternsRaise] :: TerEnv -> !Int

-- | The current guardedness status. Changes as we go deeper into the term.
--   Updated during call graph extraction, hence strict.
[terGuarded] :: TerEnv -> !Guarded

-- | When extracting usable size variables during construction of the call
--   matrix, can we take the variable for use with SIZELT constraints from
--   the context? Yes, if we are under an inductive constructor. No, if we
--   are under a record constructor. (See issue #1015).
[terUseSizeLt] :: TerEnv -> Bool

-- | Pattern variables that can be compared to argument variables using
--   SIZELT.
[terUsableVars] :: TerEnv -> VarSet

-- | An empty termination environment.
--   
--   Values are set to a safe default meaning that with these initial
--   values the termination checker will not miss termination errors it
--   would have seen with better settings of these values.
--   
--   Values that do not have a safe default are set to
--   <tt><b>IMPOSSIBLE</b></tt>.
defaultTerEnv :: TerEnv

-- | Termination monad service class.
class (Functor m, Monad m) => MonadTer m
terAsk :: MonadTer m => m TerEnv
terLocal :: MonadTer m => (TerEnv -> TerEnv) -> m a -> m a
terAsks :: MonadTer m => (TerEnv -> a) -> m a

-- | Termination monad.
newtype TerM a
TerM :: ReaderT TerEnv TCM a -> TerM a
[terM] :: TerM a -> ReaderT TerEnv TCM a

-- | Generic run method for termination monad.
runTer :: TerEnv -> TerM a -> TCM a

-- | Run TerM computation in default environment (created from options).
runTerDefault :: TerM a -> TCM a
terGetUseDotPatterns :: TerM Bool
terSetUseDotPatterns :: Bool -> TerM a -> TerM a
terGetSizeSuc :: TerM (Maybe QName)
terGetCurrent :: TerM QName
terSetCurrent :: QName -> TerM a -> TerM a
terGetSharp :: TerM (Maybe QName)
terGetCutOff :: TerM CutOff
terGetMutual :: TerM MutualNames
terGetUserNames :: TerM (Set QName)
terGetTarget :: TerM Target
terSetTarget :: Target -> TerM a -> TerM a
terGetHaveInlinedWith :: TerM Bool
terSetHaveInlinedWith :: TerM a -> TerM a
terGetMaskArgs :: TerM [Bool]
terSetMaskArgs :: [Bool] -> TerM a -> TerM a
terGetMaskResult :: TerM Bool
terSetMaskResult :: Bool -> TerM a -> TerM a
terGetPatterns :: TerM MaskedDeBruijnPatterns
terSetPatterns :: MaskedDeBruijnPatterns -> TerM a -> TerM a
terRaise :: TerM a -> TerM a
terGetGuarded :: TerM Guarded
terModifyGuarded :: (Order -> Order) -> TerM a -> TerM a
terSetGuarded :: Order -> TerM a -> TerM a
terUnguarded :: TerM a -> TerM a

-- | Lens for <a>_terSizeDepth</a>.
terSizeDepth :: Lens' TerEnv Int

-- | Lens for <a>terUsableVars</a>.
terGetUsableVars :: TerM VarSet
terModifyUsableVars :: (VarSet -> VarSet) -> TerM a -> TerM a
terSetUsableVars :: VarSet -> TerM a -> TerM a

-- | Lens for <a>terUseSizeLt</a>.
terGetUseSizeLt :: TerM Bool
terModifyUseSizeLt :: (Bool -> Bool) -> TerM a -> TerM a
terSetUseSizeLt :: Bool -> TerM a -> TerM a

-- | Compute usable vars from patterns and run subcomputation.
withUsableVars :: UsableSizeVars a => a -> TerM b -> TerM b

-- | Set <a>terUseSizeLt</a> when going under constructor <tt>c</tt>.
conUseSizeLt :: QName -> TerM a -> TerM a

-- | Set <a>terUseSizeLt</a> for arguments following projection <tt>q</tt>.
--   We disregard j&lt;i after a non-coinductive projection. However, the
--   projection need not be recursive (Issue 1470).
projUseSizeLt :: QName -> TerM a -> TerM a

-- | For termination checking purposes flat should not be considered a
--   projection. That is, it flat doesn't preserve either structural order
--   or guardedness like other projections do. Andreas, 2012-06-09: the
--   same applies to projections of recursive records.
isProjectionButNotCoinductive :: MonadTCM tcm => QName -> tcm Bool

-- | Check whether a projection belongs to a coinductive record and is
--   actually recursive. E.g. @ isCoinductiveProjection (Stream.head) =
--   return False
--   
--   isCoinductiveProjection (Stream.tail) = return True @
isCoinductiveProjection :: MonadTCM tcm => Bool -> QName -> tcm Bool

-- | How long is the path to the deepest atomic pattern?
patternDepth :: forall a. Pattern' a -> Int

-- | A dummy pattern used to mask a pattern that cannot be used for
--   structural descent.
unusedVar :: DeBruijnPattern

-- | Extract variables from <a>DeBruijnPattern</a>s that could witness a
--   decrease via a SIZELT constraint.
--   
--   These variables must be under an inductive constructor (with no record
--   constructor in the way), or after a coinductive projection (with no
--   inductive one in the way).
class UsableSizeVars a
usableSizeVars :: UsableSizeVars a => a -> TerM VarSet
type MaskedDeBruijnPatterns = [Masked DeBruijnPattern]
data Masked a
Masked :: Bool -> a -> Masked a

-- | True if thing not eligible for structural descent.
[getMask] :: Masked a -> Bool

-- | Thing.
[getMasked] :: Masked a -> a
masked :: a -> Masked a
notMasked :: a -> Masked a

-- | Call paths.
newtype CallPath
CallPath :: DList CallInfo -> CallPath

-- | The calls making up the call path.
callInfos :: CallPath -> [CallInfo]

-- | A very crude way of estimating the <tt>SIZELT</tt> chains <tt>i &gt; j
--   &gt; k</tt> in context. Returns 3 in this case. Overapproximates.
class TerSetSizeDepth b
terSetSizeDepth :: TerSetSizeDepth b => b -> TerM a -> TerM a
instance GHC.Show.Show Agda.Termination.Monad.Target
instance GHC.Classes.Eq Agda.Termination.Monad.Target
instance Data.Traversable.Traversable Agda.Termination.Monad.Masked
instance Data.Foldable.Foldable Agda.Termination.Monad.Masked
instance GHC.Base.Functor Agda.Termination.Monad.Masked
instance GHC.Show.Show a => GHC.Show.Show (Agda.Termination.Monad.Masked a)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.Termination.Monad.Masked a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.Termination.Monad.Masked a)
instance Agda.TypeChecking.Monad.Pure.PureTCM Agda.Termination.Monad.TerM
instance Agda.TypeChecking.Monad.Context.MonadAddContext Agda.Termination.Monad.TerM
instance Agda.TypeChecking.Monad.Base.MonadReduce Agda.Termination.Monad.TerM
instance Agda.TypeChecking.Monad.Base.ReadTCState Agda.Termination.Monad.TerM
instance Agda.TypeChecking.Monad.Base.MonadTCM Agda.Termination.Monad.TerM
instance Agda.TypeChecking.Monad.Base.MonadTCState Agda.Termination.Monad.TerM
instance Agda.TypeChecking.Monad.Base.MonadTCEnv Agda.Termination.Monad.TerM
instance Control.Monad.IO.Class.MonadIO Agda.Termination.Monad.TerM
instance Agda.TypeChecking.Monad.Signature.HasConstInfo Agda.Termination.Monad.TerM
instance Agda.TypeChecking.Monad.Debug.MonadDebug Agda.Termination.Monad.TerM
instance Agda.TypeChecking.Monad.Builtin.HasBuiltins Agda.Termination.Monad.TerM
instance Agda.Interaction.Options.HasOptions.HasOptions Agda.Termination.Monad.TerM
instance Agda.TypeChecking.Monad.Statistics.MonadStatistics Agda.Termination.Monad.TerM
instance Control.Monad.Error.Class.MonadError Agda.TypeChecking.Monad.Base.TCErr Agda.Termination.Monad.TerM
instance Control.Monad.Fail.MonadFail Agda.Termination.Monad.TerM
instance GHC.Base.Monad Agda.Termination.Monad.TerM
instance GHC.Base.Applicative Agda.Termination.Monad.TerM
instance GHC.Base.Functor Agda.Termination.Monad.TerM
instance GHC.Base.Monoid Agda.Termination.Monad.CallPath
instance GHC.Base.Semigroup Agda.Termination.Monad.CallPath
instance GHC.Show.Show Agda.Termination.Monad.CallPath
instance Agda.Termination.Monad.TerSetSizeDepth Agda.Syntax.Internal.Telescope
instance Agda.Termination.Monad.TerSetSizeDepth Agda.Syntax.Internal.ListTel
instance Agda.Syntax.Common.Pretty.Pretty Agda.Termination.Monad.CallPath
instance Agda.Termination.Monad.MonadTer Agda.Termination.Monad.TerM
instance Agda.Termination.Monad.UsableSizeVars Agda.Syntax.Internal.DeBruijnPattern
instance Agda.Termination.Monad.UsableSizeVars [Agda.Syntax.Internal.DeBruijnPattern]
instance Agda.Termination.Monad.UsableSizeVars (Agda.Termination.Monad.Masked Agda.Syntax.Internal.DeBruijnPattern)
instance Agda.Termination.Monad.UsableSizeVars Agda.Termination.Monad.MaskedDeBruijnPatterns
instance Agda.Utils.Benchmark.MonadBench Agda.Termination.Monad.TerM
instance GHC.Base.Semigroup m => GHC.Base.Semigroup (Agda.Termination.Monad.TerM m)
instance (GHC.Base.Semigroup m, GHC.Base.Monoid m) => GHC.Base.Monoid (Agda.Termination.Monad.TerM m)
instance Agda.Utils.Functor.Decoration Agda.Termination.Monad.Masked
instance Agda.TypeChecking.Pretty.PrettyTCM a => Agda.TypeChecking.Pretty.PrettyTCM (Agda.Termination.Monad.Masked a)

module Agda.TypeChecking.Errors
renderError :: MonadTCM tcm => TCErr -> tcm String
prettyError :: MonadTCM tcm => TCErr -> tcm Doc
tcErrString :: TCErr -> String
prettyTCWarnings' :: [TCWarning] -> TCM [Doc]
prettyTCWarnings :: [TCWarning] -> TCM String

-- | Turns warnings, if any, into errors.
tcWarningsToError :: [TCWarning] -> TCM ()

-- | Depending which flags are set, one may happily ignore some warnings.
applyFlagsToTCWarningsPreserving :: HasOptions m => Set WarningName -> [TCWarning] -> m [TCWarning]
applyFlagsToTCWarnings :: HasOptions m => [TCWarning] -> m [TCWarning]
getAllUnsolvedWarnings :: (MonadFail m, ReadTCState m, MonadWarning m, MonadTCM m) => m [TCWarning]
getAllWarningsPreserving :: (MonadFail m, ReadTCState m, MonadWarning m, MonadTCM m) => Set WarningName -> WhichWarnings -> m [TCWarning]

-- | Collect all warnings that have accumulated in the state.
getAllWarnings :: (MonadFail m, ReadTCState m, MonadWarning m, MonadTCM m) => WhichWarnings -> m [TCWarning]
getAllWarningsOfTCErr :: TCErr -> TCM [TCWarning]

-- | Drops the filename component of the qualified name.
dropTopLevelModule :: MonadPretty m => QName -> m QName

-- | Produces a function which drops the filename component of the
--   qualified name.
topLevelModuleDropper :: (MonadDebug m, MonadTCEnv m, ReadTCState m) => m (QName -> QName)
stringTCErr :: String -> TCErr
explainWhyInScope :: forall m. MonadPretty m => WhyInScopeData -> m Doc
class Verbalize a
verbalize :: Verbalize a => a -> String
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.TypeError
instance Agda.TypeChecking.Errors.Verbalize a => Agda.TypeChecking.Errors.Verbalize (Agda.TypeChecking.Errors.Indefinite a)
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.UnificationFailure
instance Agda.TypeChecking.Errors.Verbalize Agda.Syntax.Common.Hiding
instance Agda.TypeChecking.Errors.Verbalize Agda.Syntax.Common.Relevance
instance Agda.TypeChecking.Errors.Verbalize Agda.Syntax.Common.Quantity
instance Agda.TypeChecking.Errors.Verbalize Agda.Syntax.Common.Cohesion
instance Agda.TypeChecking.Errors.Verbalize Agda.Syntax.Common.Modality
instance Agda.TypeChecking.Errors.PrettyUnequal Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Errors.PrettyUnequal Agda.Syntax.Internal.Type
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.TCErr
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.SplitError
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.NegativeUnification

module Agda.TypeChecking.Pretty.Constraint
prettyConstraint :: MonadPretty m => ProblemConstraint -> m Doc
interestingConstraint :: ProblemConstraint -> Bool
prettyInterestingConstraints :: MonadPretty m => [ProblemConstraint] -> m [Doc]
prettyRangeConstraint :: (MonadPretty m, Foldable f, Null (f ProblemId)) => Range -> f ProblemId -> Blocker -> Doc -> m Doc
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.ProblemConstraint
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Monad.Base.Constraint

module Agda.TypeChecking.SizedTypes

-- | Check whether a type is either not a SIZELT or a SIZELT that is
--   non-empty.
checkSizeLtSat :: Term -> TCM ()

-- | Precondition: Term is reduced and not blocked. Throws a
--   <a>patternViolation</a> if undecided
checkSizeNeverZero :: Term -> TCM Bool

-- | Checks that a size variable is ensured to be <tt>&gt; 0</tt>. E.g.
--   variable <tt>i</tt> cannot be zero in context <tt>(i : Size) (j :
--   Size&lt; ↑ ↑ i) (k : Size&lt; j) (k' : Size&lt; k)</tt>. Throws a
--   <a>patternViolation</a> if undecided.
checkSizeVarNeverZero :: Int -> TCM Bool

-- | Check whether a variable in the context is bounded by a size
--   expression. If <tt>x : Size&lt; a</tt>, then <tt>a</tt> is returned.
isBounded :: PureTCM m => Nat -> m BoundedSize
isBoundedProjVar :: (MonadCheckInternal m, PureTCM m) => ProjectedVar -> m BoundedSize
isBoundedSizeType :: PureTCM m => Type -> m BoundedSize

-- | Whenever we create a bounded size meta, add a constraint expressing
--   the bound. First argument is the new meta and must be a
--   <tt>MetaV{}</tt>. In <tt>boundedSizeMetaHook v tel a</tt>,
--   <tt>tel</tt> includes the current context.
boundedSizeMetaHook :: (MonadConstraint m, MonadTCEnv m, ReadTCState m, MonadAddContext m, HasOptions m, HasBuiltins m) => Term -> Telescope -> Type -> m ()

-- | <tt>trySizeUniv cmp t m n x els1 y els2</tt> is called as a last
--   resort when conversion checking <tt>m <tt>cmp</tt> n : t</tt> failed
--   for definitions <tt>m = x els1</tt> and <tt>n = y els2</tt>, where the
--   heads <tt>x</tt> and <tt>y</tt> are not equal.
--   
--   <tt>trySizeUniv</tt> accounts for subtyping between SIZELT and SIZE,
--   like <tt>Size&lt; i =&lt; Size</tt>.
--   
--   If it does not succeed it reports failure of conversion check.
trySizeUniv :: MonadConversion m => Comparison -> CompareAs -> Term -> Term -> QName -> Elims -> QName -> Elims -> m ()

-- | Compute the deep size view of a term. Precondition: sized types are
--   enabled.
deepSizeView :: (PureTCM m, MonadTCError m) => Term -> m DeepSizeView
sizeMaxView :: PureTCM m => Term -> m SizeMaxView

-- | Compare two sizes.
compareSizes :: MonadConversion m => Comparison -> Term -> Term -> m ()

-- | Compare two sizes in max view.
compareMaxViews :: MonadConversion m => Comparison -> SizeMaxView -> SizeMaxView -> m ()

-- | <tt>compareBelowMax u vs</tt> checks <tt>u &lt;= max vs</tt>.
--   Precondition: <tt>size vs &gt;= 2</tt>
compareBelowMax :: MonadConversion m => DeepSizeView -> SizeMaxView -> m ()
compareSizeViews :: MonadConversion m => Comparison -> DeepSizeView -> DeepSizeView -> m ()

-- | If <a>envAssignMetas</a> then postpone as constraint, otherwise, fail
--   hard. Failing is required if we speculatively test several
--   alternatives.
giveUp :: MonadConversion m => Comparison -> Type -> Term -> Term -> m ()

-- | Checked whether a size constraint is trivial (like <tt>X &lt;=
--   X+1</tt>).
trivial :: MonadConversion m => Term -> Term -> m Bool

-- | Test whether a problem consists only of size constraints.
isSizeProblem :: (ReadTCState m, HasOptions m, HasBuiltins m) => ProblemId -> m Bool

-- | Test whether a constraint speaks about sizes.
isSizeConstraint :: (HasOptions m, HasBuiltins m) => (Comparison -> Bool) -> Closure Constraint -> m Bool
mkIsSizeConstraint :: (Term -> Maybe BoundedSize) -> (Comparison -> Bool) -> Closure Constraint -> Bool
isSizeConstraint_ :: (Type -> Bool) -> (Comparison -> Bool) -> Closure Constraint -> Bool

-- | Take out all size constraints of the given direction (DANGER!).
takeSizeConstraints :: (Comparison -> Bool) -> TCM [ProblemConstraint]

-- | Find the size constraints of the matching direction.
getSizeConstraints :: (Comparison -> Bool) -> TCM [ProblemConstraint]

-- | Return a list of size metas and their context.
getSizeMetas :: Bool -> TCM [(MetaId, Type, Telescope)]

-- | Atomic size expressions.
data OldSizeExpr

-- | A size meta applied to de Bruijn indices.
SizeMeta :: MetaId -> [Int] -> OldSizeExpr

-- | A de Bruijn index.
Rigid :: Int -> OldSizeExpr

-- | Size constraints we can solve.
data OldSizeConstraint

-- | <tt>Leq a +n b</tt> represents <tt>a =&lt; b + n</tt>. <tt>Leq a -n
--   b</tt> represents <tt>a + n =&lt; b</tt>.
Leq :: OldSizeExpr -> Int -> OldSizeExpr -> OldSizeConstraint

-- | Compute a set of size constraints that all live in the same context
--   from constraints over terms of type size that may live in different
--   contexts.
--   
--   cf. <a>simplifyLevelConstraint</a>
oldComputeSizeConstraints :: [ProblemConstraint] -> TCM [OldSizeConstraint]

-- | Turn a constraint over de Bruijn indices into a size constraint.
oldComputeSizeConstraint :: Constraint -> TCM (Maybe OldSizeConstraint)

-- | Turn a term with de Bruijn indices into a size expression with offset.
--   
--   Throws a <a>patternViolation</a> if the term isn't a proper size
--   expression.
oldSizeExpr :: (PureTCM m, MonadBlock m) => Term -> m (OldSizeExpr, Int)

-- | Compute list of size metavariables with their arguments appearing in a
--   constraint.
flexibleVariables :: OldSizeConstraint -> [(MetaId, [Int])]

-- | Convert size constraint into form where each meta is applied to
--   indices <tt>0,1,..,n-1</tt> where <tt>n</tt> is the arity of that
--   meta.
--   
--   <tt>X[σ] &lt;= t</tt> becomes <tt>X[id] &lt;= t[σ^-1]</tt>
--   
--   <tt>X[σ] ≤ Y[τ]</tt> becomes <tt>X[id] ≤ Y[τ[σ^-1]]</tt> or
--   <tt>X[σ[τ^1]] ≤ Y[id]</tt> whichever is defined. If none is defined,
--   we give up.
oldCanonicalizeSizeConstraint :: OldSizeConstraint -> Maybe OldSizeConstraint
instance GHC.Show.Show Agda.TypeChecking.SizedTypes.OldSizeExpr
instance GHC.Classes.Eq Agda.TypeChecking.SizedTypes.OldSizeExpr
instance GHC.Show.Show Agda.TypeChecking.SizedTypes.OldSizeConstraint
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.SizedTypes.OldSizeConstraint
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.SizedTypes.OldSizeExpr


-- | Computing the polarity (variance) of function arguments, for the sake
--   of subtyping.
module Agda.TypeChecking.Polarity

-- | Main function of this module.
computePolarity :: (HasOptions m, HasConstInfo m, HasBuiltins m, MonadTCEnv m, MonadTCState m, MonadReduce m, MonadAddContext m, MonadTCError m, MonadDebug m, MonadPretty m) => [QName] -> m ()

-- | What is the polarity of a function composition?
composePol :: Polarity -> Polarity -> Polarity

-- | Get the next polarity from a list, <a>Invariant</a> if empty.
nextPolarity :: [Polarity] -> (Polarity, [Polarity])

-- | Replace <a>Nonvariant</a> by <a>Covariant</a>. (Arbitrary bias, but
--   better than <a>Invariant</a>, see issue 1596).
purgeNonvariant :: [Polarity] -> [Polarity]
polFromOcc :: Occurrence -> Polarity
instance Agda.TypeChecking.Polarity.HasPolarity a => Agda.TypeChecking.Polarity.HasPolarity [a]
instance Agda.TypeChecking.Polarity.HasPolarity a => Agda.TypeChecking.Polarity.HasPolarity (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Polarity.HasPolarity a => Agda.TypeChecking.Polarity.HasPolarity (Agda.Syntax.Internal.Dom a)
instance Agda.TypeChecking.Polarity.HasPolarity a => Agda.TypeChecking.Polarity.HasPolarity (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.TypeChecking.Polarity.HasPolarity a => Agda.TypeChecking.Polarity.HasPolarity (Agda.Syntax.Internal.Level' a)
instance Agda.TypeChecking.Polarity.HasPolarity a => Agda.TypeChecking.Polarity.HasPolarity (Agda.Syntax.Internal.PlusLevel' a)
instance Agda.TypeChecking.Polarity.HasPolarity a => Agda.TypeChecking.Polarity.HasPolarity (Agda.Syntax.Internal.Type'' t a)
instance (Agda.TypeChecking.Polarity.HasPolarity a, Agda.TypeChecking.Polarity.HasPolarity b) => Agda.TypeChecking.Polarity.HasPolarity (a, b)
instance Agda.TypeChecking.Polarity.HasPolarity a => Agda.TypeChecking.Polarity.HasPolarity (Agda.Syntax.Internal.Abs a)
instance Agda.TypeChecking.Polarity.HasPolarity Agda.Syntax.Internal.Term
instance GHC.Base.Monad m => Agda.Utils.Singleton.Singleton Agda.TypeChecking.Monad.Base.Polarity (Agda.TypeChecking.Polarity.LeastPolarity m)
instance GHC.Base.Monad m => GHC.Base.Semigroup (Agda.TypeChecking.Polarity.LeastPolarity m)
instance GHC.Base.Monad m => GHC.Base.Monoid (Agda.TypeChecking.Polarity.LeastPolarity m)


-- | <a>Injectivity</a>, or more precisely, "constructor headedness", is a
--   property of functions defined by pattern matching that helps us solve
--   constraints involving blocked applications of such functions.
--   <a>Blocked</a> shall mean here that pattern matching is blocked on a
--   meta variable, and constructor headedness lets us learn more about
--   that meta variable.
--   
--   Consider the simple example: <tt> isZero : Nat -&gt; Bool isZero zero
--   = true isZero (suc n) = false </tt> This function is
--   constructor-headed, meaning that all rhss are headed by a distinct
--   constructor. Thus, on a constraint like <tt> isZero ?X = false : Bool
--   </tt> involving an application of <tt>isZero</tt> that is blocked on
--   meta variable <tt>?X</tt>, we can exploit injectivity and learn that
--   <tt>?X = suc ?Y</tt> for a new meta-variable <tt>?Y</tt>.
--   
--   Which functions qualify for injectivity?
--   
--   <ol>
--   <li>The function needs to have at least one non-absurd clause that has
--   a proper match, meaning that the function can actually be blocked on a
--   meta. Proper matches are these patterns:</li>
--   </ol>
--   
--   <ul>
--   <li>data constructor (<tt>ConP</tt>, but not record constructor)</li>
--   <li>literal (<tt>LitP</tt>)</li>
--   <li>HIT-patterns (<tt>DefP</tt>)</li>
--   </ul>
--   
--   Projection patterns (<tt>ProjP</tt>) are excluded because metas cannot
--   occupy their place!
--   
--   <ol>
--   <li>All the clauses that satisfy (1.) need to be headed by a distinct
--   constructor.</li>
--   </ol>
module Agda.TypeChecking.Injectivity
headSymbol :: Term -> TCM (Maybe TermHead)

-- | Is this a matchable definition, or constructor, which reduces based on
--   interval substitutions?
isUnstableDef :: PureTCM m => QName -> m Bool

-- | Do a full whnf and treat neutral terms as rigid. Used on the arguments
--   to an injective functions and to the right-hand side. Only returns
--   heads which are stable under interval substitution, i.e. NOT path
--   constructors or generated hcomp/transp!
headSymbol' :: (PureTCM m, MonadError TCErr m) => Term -> m (Maybe TermHead)

-- | Does deBruijn variable i correspond to a top-level argument, and if so
--   which one (index from the left).
topLevelArg :: Clause -> Int -> Maybe TermHead

-- | Join a list of inversion maps.
joinHeadMaps :: [InversionMap c] -> InversionMap c

-- | Update the heads of an inversion map.
updateHeads :: Monad m => (TermHead -> [c] -> m TermHead) -> InversionMap c -> m (InversionMap c)
checkInjectivity :: QName -> [Clause] -> TCM FunctionInverse

-- | Precondition: all the given clauses are non-absurd and contain a
--   proper match.
checkInjectivity' :: QName -> [Clause] -> TCM FunctionInverse

-- | If a clause is over-applied we can't trust the head (Issue 2944). For
--   instance, the clause might be `f ps = u , v` and the actual call `f vs
--   .fst`. In this case the head will be the head of <tt>u</tt> rather
--   than `_,_`.
checkOverapplication :: forall m. HasConstInfo m => Elims -> InversionMap Clause -> m (InversionMap Clause)

-- | Turn variable heads, referring to top-level argument positions, into
--   proper heads. These might still be <a>VarHead</a>, but in that case
--   they refer to deBruijn variables. Checks that the instantiated heads
--   are still rigid and distinct.
instantiateVarHeads :: forall m c. (PureTCM m, MonadError TCErr m) => QName -> Elims -> InversionMap c -> m (Maybe (InversionMap c))

-- | Argument should be in weak head normal form.
functionInverse :: (PureTCM m, MonadError TCErr m) => Term -> m InvView
data InvView
Inv :: QName -> [Elim] -> InversionMap Clause -> InvView
NoInv :: InvView

-- | Precondition: The first term must be blocked on the given meta and the
--   second must be neutral.
useInjectivity :: MonadConversion m => CompareDirection -> Blocker -> CompareAs -> Term -> Term -> m ()

-- | The second argument should be a blocked application and the third
--   argument the inverse of the applied function.
invertFunction :: MonadConversion m => Comparison -> Term -> InvView -> TermHead -> m () -> m () -> (Term -> m ()) -> m ()
forcePiUsingInjectivity :: Type -> TCM Type

module Agda.TypeChecking.InstanceArguments

-- | <tt>findInstance m (v,a)s</tt> tries to instantiate on of the types
--   <tt>a</tt>s of the candidate terms <tt>v</tt>s to the type <tt>t</tt>
--   of the metavariable <tt>m</tt>. If successful, meta <tt>m</tt> is
--   solved with the instantiation of <tt>v</tt>. If unsuccessful, the
--   constraint is regenerated, with possibly reduced candidate set. The
--   list of candidates is equal to <tt>Nothing</tt> when the type of the
--   meta wasn't known when the constraint was generated. In that case, try
--   to find its type again.
findInstance :: MetaId -> Maybe [Candidate] -> TCM ()
isInstanceConstraint :: Constraint -> Bool
solveAwakeInstanceConstraints :: TCM ()
shouldPostponeInstanceSearch :: (ReadTCState m, HasOptions m) => m Bool
postponeInstanceConstraints :: TCM a -> TCM a

-- | Entry point for <tt>tcGetInstances</tt> primitive
getInstanceCandidates :: MetaId -> TCM (Either Blocker [Candidate])

-- | Try to solve the instance definitions whose type is not yet known,
--   report an error if it doesn't work and return the instance table
--   otherwise.
getInstanceDefs :: TCM InstanceTable
data OutputTypeName
OutputTypeName :: QName -> OutputTypeName
OutputTypeVar :: OutputTypeName
OutputTypeVisiblePi :: OutputTypeName
OutputTypeNameNotYetKnown :: Blocker -> OutputTypeName
NoOutputTypeName :: OutputTypeName

-- | Strips all hidden and instance Pi's and return the argument telescope,
--   the head term, and its name, if possible.
getOutputTypeName :: Type -> TCM (Telescope, Term, OutputTypeName)

-- | Register the definition with the given type as an instance. Issue
--   warnings if instance is unusable.
addTypedInstance :: QName -> Type -> TCM ()

-- | Register the definition with the given type as an instance.
addTypedInstance' :: Bool -> Maybe InstanceInfo -> QName -> Type -> TCM ()

-- | Prune an <a>Interface</a> to remove any instances that would be
--   inapplicable in child modules.
--   
--   While in a section with visible arguments, we add any instances
--   defined locally to the instance table: you have to be able to find
--   them, after all! Conservatively, all of the local variables are turned
--   into <tt>FlexK</tt>s, i.e., wildcards.
--   
--   But when we leave such a section, these instances have no more value:
--   even though they might technically be in scope, their types are
--   malformed, since they have visible pis.
--   
--   This function deletes these instances from the instance tree in the
--   given signature to save on serialisation time *and* time spent
--   checking for candidate validity in client modules. It can't do this
--   directly in the TC state to prevent these instances from going out of
--   scope before interaction (see #7196).
pruneTemporaryInstances :: Interface -> TCM Interface
resolveInstanceHead :: QName -> TCM ()
instance GHC.Show.Show Agda.TypeChecking.InstanceArguments.YesNo

module Agda.TypeChecking.Constraints
addConstraintTCM :: Blocker -> Constraint -> TCM ()
wakeConstraintsTCM :: (ProblemConstraint -> WakeUp) -> TCM ()

-- | Add all constraints belonging to the given problem to the current
--   problem(s).
stealConstraintsTCM :: ProblemId -> TCM ()

-- | Don't allow the argument to produce any blocking constraints.
--   
--   WARNING: this does not mean that the given computation cannot
--   constrain the solution space further. It can well do so, by solving
--   metas.
noConstraints :: (MonadConstraint m, MonadWarning m, MonadError TCErr m, MonadFresh ProblemId m) => m a -> m a

-- | As noConstraints but also fail for non-blocking constraints.
reallyNoConstraints :: (MonadConstraint m, MonadWarning m, MonadError TCErr m, MonadFresh ProblemId m) => m a -> m a
noConstraints' :: (MonadConstraint m, MonadWarning m, MonadError TCErr m, MonadFresh ProblemId m) => Bool -> m a -> m a

-- | Run a computation that should succeeds without constraining the
--   solution space, i.e., not add any information about meta-variables.
nonConstraining :: (HasOptions m, MonadConstraint m, MonadDebug m, MonadError TCErr m, MonadFresh ProblemId m, MonadTCEnv m, MonadWarning m) => m a -> m a

-- | Create a fresh problem for the given action.
newProblem :: (MonadFresh ProblemId m, MonadConstraint m) => m a -> m (ProblemId, a)
newProblem_ :: (MonadFresh ProblemId m, MonadConstraint m) => m a -> m ProblemId
ifNoConstraints :: TCM a -> (a -> TCM b) -> (ProblemId -> a -> TCM b) -> TCM b
ifNoConstraints_ :: TCM () -> TCM a -> (ProblemId -> TCM a) -> TCM a

-- | <tt>guardConstraint c blocker</tt> tries to solve <tt>blocker</tt>
--   first. If successful without constraints, it moves on to solve
--   <tt>c</tt>, otherwise it adds a <tt>c</tt> to the constraint pool,
--   blocked by the problem generated by <tt>blocker</tt>.
guardConstraint :: Constraint -> TCM () -> TCM ()
whenConstraints :: TCM () -> TCM () -> TCM ()

-- | Wake up the constraints depending on the given meta.
wakeupConstraints :: MonadMetaSolver m => MetaId -> m ()

-- | Wake up all constraints not blocked on a problem.
wakeupConstraints_ :: TCM ()

-- | Solve awake constraints matching the predicate. If the second argument
--   is True solve constraints even if already <a>isSolvingConstraints</a>.
solveSomeAwakeConstraintsTCM :: (ProblemConstraint -> Bool) -> Bool -> TCM ()
solveConstraintTCM :: Constraint -> TCM ()
solveConstraint_ :: Constraint -> TCM ()
checkTypeCheckingProblem :: TypeCheckingProblem -> TCM Term
debugConstraints :: TCM ()
updateBlocker :: PureTCM m => Blocker -> m Blocker
addAndUnblocker :: (PureTCM m, MonadBlock m) => Blocker -> m a -> m a
addOrUnblocker :: (PureTCM m, MonadBlock m) => Blocker -> m a -> m a
withReduced :: (Reduce a, IsMeta a, PureTCM m, MonadBlock m) => a -> (a -> m b) -> m b
instance Agda.TypeChecking.Monad.Constraints.MonadConstraint Agda.TypeChecking.Monad.Base.TCM


-- | Unification algorithm for specializing datatype indices, as described
--   in "Unifiers as Equivalences: Proof-Relevant Unification of
--   Dependently Typed Data" by Jesper Cockx, Dominique Devriese, and Frank
--   Piessens (ICFP 2016).
--   
--   This is the unification algorithm used for checking the left-hand side
--   of clauses (see <tt>Agda.TypeChecking.Rules.LHS</tt>), coverage
--   checking (see <tt>Agda.TypeChecking.Coverage</tt>) and indirectly also
--   for interactive case splitting (see
--   <tt>Agda.Interaction.MakeCase</tt>).
--   
--   A unification problem (of type <tt>UnifyState</tt>) consists of:
--   
--   <ol>
--   <li>A telescope <tt>varTel</tt> of free variables, some or all of
--   which are flexible (as indicated by <tt>flexVars</tt>).</li>
--   <li>A telescope <tt>eqTel</tt> containing the types of the
--   equations.</li>
--   <li>Left- and right-hand sides for each equation: <tt>varTel ⊢ eqLHS :
--   eqTel</tt> and <tt>varTel ⊢ eqRHS : eqTel</tt>.</li>
--   </ol>
--   
--   The unification algorithm can end in three different ways: (type
--   <tt>UnificationResult</tt>):
--   
--   <ul>
--   <li>A *positive success* <tt>Unifies (tel, sigma, ps)</tt> with
--   <tt>tel ⊢ sigma : varTel</tt>, <tt>tel ⊢ eqLHS [ varTel ↦ sigma ] ≡
--   eqRHS [ varTel ↦ sigma ] : eqTel</tt>, and <tt>tel ⊢ ps : eqTel</tt>.
--   In this case, <tt>sigma;ps</tt> is an *equivalence* between the
--   telescopes <tt>tel</tt> and <tt>varTel(eqLHS ≡ eqRHS)</tt>.</li>
--   <li>A *negative success* <tt>NoUnify err</tt> means that a conflicting
--   equation was found (e.g an equation between two distinct constructors
--   or a cycle).</li>
--   <li>A *failure* <tt>UnifyStuck err</tt> means that the unifier got
--   stuck.</li>
--   </ul>
--   
--   The unification algorithm itself consists of two parts:
--   
--   <ol>
--   <li>A *unification strategy* takes a unification problem and produces
--   a list of suggested unification rules (of type <tt>UnifyStep</tt>).
--   Strategies can be constructed by composing simpler strategies (see for
--   example the definition of <tt>completeStrategyAt</tt>).</li>
--   <li>The *unification engine* <tt>unifyStep</tt> takes a unification
--   rule and tries to apply it to the given state, writing the result to
--   the UnifyOutput on a success.</li>
--   </ol>
--   
--   The unification steps (of type <tt>UnifyStep</tt>) are the following:
--   
--   <ul>
--   <li>*Deletion* removes a reflexive equation <tt>u =?= v : a</tt> if
--   the left- and right-hand side <tt>u</tt> and <tt>v</tt> are
--   (definitionally) equal. This rule results in a failure if --without-K
--   is enabled (see "Pattern Matching Without K" by Jesper Cockx,
--   Dominique Devriese, and Frank Piessens (ICFP 2014).</li>
--   <li>*Solution* solves an equation if one side is (eta-equivalent to) a
--   flexible variable. In case both sides are flexible variables, the
--   unification strategy makes a choice according to the
--   <tt>chooseFlex</tt> function in
--   <tt>Agda.TypeChecking.Rules.LHS.Problem</tt>.</li>
--   <li>*Injectivity* decomposes an equation of the form <tt>c us =?= c vs
--   : D pars is</tt> where <tt>c : Δc → D pars js</tt> is a constructor of
--   the inductive datatype <tt>D</tt> into a sequence of equations <tt>us
--   =?= vs : delta</tt>. In case <tt>D</tt> is an indexed datatype,</li>
--   <li>higher-dimensional unification* is applied (see below).</li>
--   <li>*Conflict* detects absurd equations of the form <tt>c₁ us =?= c₂
--   vs : D pars is</tt> where <tt>c₁</tt> and <tt>c₂</tt> are two distinct
--   constructors of the datatype <tt>D</tt>.</li>
--   <li>*Cycle* detects absurd equations of the form <tt>x =?= v : D pars
--   is</tt> where <tt>x</tt> is a variable of the datatype <tt>D</tt> that
--   occurs strongly rigid in <tt>v</tt>.</li>
--   <li>*EtaExpandVar* eta-expands a single flexible variable <tt>x :
--   R</tt> where <tt>R</tt> is a (eta-expandable) record type, replacing
--   it by one variable for each field of <tt>R</tt>.</li>
--   <li>*EtaExpandEquation* eta-expands an equation <tt>u =?= v : R</tt>
--   where <tt>R</tt> is a (eta-expandable) record type, replacing it by
--   one equation for each field of <tt>R</tt>. The left- and right-hand
--   sides of these equations are the projections of <tt>u</tt> and
--   <tt>v</tt>.</li>
--   <li>*LitConflict* detects absurd equations of the form <tt>l₁ =?= l₂ :
--   A</tt> where <tt>l₁</tt> and <tt>l₂</tt> are distinct literal
--   terms.</li>
--   <li>*StripSizeSuc* simplifies an equation of the form <tt>sizeSuc x
--   =?= sizeSuc y : Size</tt> to <tt>x =?= y : Size</tt>.</li>
--   <li>*SkipIrrelevantEquation@ removes an equation between irrelevant
--   terms.</li>
--   <li>*TypeConInjectivity* decomposes an equation of the form <tt>D us
--   =?= D vs : Set i</tt> where <tt>D</tt> is a datatype. This rule is
--   only used if --injective-type-constructors is enabled.</li>
--   </ul>
--   
--   Higher-dimensional unification (new, does not yet appear in any
--   paper): If an equation of the form <tt>c us =?= c vs : D pars is</tt>
--   is encountered where <tt>c : Δc → D pars js</tt> is a constructor of
--   an indexed datatype <tt>D pars : Φ → Set ℓ</tt>, it is in general
--   unsound to just simplify this equation to <tt>us =?= vs : Δc</tt>. For
--   this reason, the injectivity rule in the paper restricts the indices
--   <tt>is</tt> to be distinct variables that are bound in the telescope
--   <tt>eqTel</tt>. But we can be more general by introducing new
--   variables <tt>ks</tt> to the telescope <tt>eqTel</tt> and equating
--   these to <tt>is</tt>: <tt> Δ₁(x : D pars is)Δ₂ ≃ Δ₁(ks : Φ)(x : D pars
--   ks)(ps : is ≡Φ ks)Δ₂ </tt> Since <tt>ks</tt> are distinct variables,
--   it's now possible to apply injectivity to the equation <tt>x</tt>,
--   resulting in the following new equation telescope: <tt> Δ₁(ys : Δc)(ps
--   : is ≡Φ js[Δc ↦ ys])Δ₂ </tt> Now we can solve the equations
--   <tt>ps</tt> by recursively calling the unification algorithm with
--   flexible variables <tt>Δ₁(ys : Δc)</tt>. This is called
--   *higher-dimensional unification* since we are unifying equality proofs
--   rather than terms. If the higher-dimensional unification succeeds, the
--   resulting telescope serves as the new equation telescope for the
--   original unification problem.
module Agda.TypeChecking.Rules.LHS.Unify

-- | Result of <a>unifyIndices</a>.
type UnificationResult = UnificationResult' (Telescope, PatternSubstitution, [NamedArg DeBruijnPattern])
data UnificationResult' a

-- | Unification succeeded.
Unifies :: a -> UnificationResult' a

-- | Terms are not unifiable.
NoUnify :: NegativeUnification -> UnificationResult' a

-- | Unification got blocked on a metavariable
UnifyBlocked :: Blocker -> UnificationResult' a

-- | Some other error happened, unification got stuck.
UnifyStuck :: [UnificationFailure] -> UnificationResult' a
data NoLeftInv
UnsupportedYet :: UnifyStep -> NoLeftInv
[badStep] :: NoLeftInv -> UnifyStep
Illegal :: UnifyStep -> NoLeftInv
[badStep] :: NoLeftInv -> UnifyStep
NoCubical :: NoLeftInv
WithKEnabled :: NoLeftInv

-- | splitting on a Strict Set.
SplitOnStrict :: NoLeftInv

-- | splitting on a @♭ argument
SplitOnFlat :: NoLeftInv
UnsupportedCxt :: NoLeftInv
unifyIndices' :: (PureTCM m, MonadError TCErr m) => Maybe NoLeftInv -> Telescope -> FlexibleVars -> Type -> Args -> Args -> m FullUnificationResult

-- | Unify indices.
--   
--   In <tt>unifyIndices gamma flex a us vs</tt>,
--   
--   <ul>
--   <li><tt>us</tt> and <tt>vs</tt> are the argument lists to unify,
--   eliminating type <tt>a</tt>.</li>
--   <li><tt>gamma</tt> is the telescope of free variables in <tt>us</tt>
--   and <tt>vs</tt>.</li>
--   <li><tt>flex</tt> is the set of flexible (instantiable) variabes in
--   <tt>us</tt> and <tt>vs</tt>.</li>
--   </ul>
--   
--   The result is the most general unifier of <tt>us</tt> and <tt>vs</tt>.
unifyIndices :: (PureTCM m, MonadBench m, BenchPhase m ~ Phase, MonadError TCErr m) => Maybe NoLeftInv -> Telescope -> FlexibleVars -> Type -> Args -> Args -> m UnificationResult
instance Data.Traversable.Traversable Agda.TypeChecking.Rules.LHS.Unify.UnificationResult'
instance Data.Foldable.Foldable Agda.TypeChecking.Rules.LHS.Unify.UnificationResult'
instance GHC.Base.Functor Agda.TypeChecking.Rules.LHS.Unify.UnificationResult'
instance GHC.Show.Show a => GHC.Show.Show (Agda.TypeChecking.Rules.LHS.Unify.UnificationResult' a)
instance GHC.Show.Show Agda.TypeChecking.Rules.LHS.Unify.RetryNormalised
instance GHC.Classes.Eq Agda.TypeChecking.Rules.LHS.Unify.RetryNormalised


-- | The occurs check for unification. Does pruning on the fly.
--   
--   When hitting a meta variable:
--   
--   <ul>
--   <li>Compute flex/rigid for its arguments.</li>
--   <li>Compare to allowed variables.</li>
--   <li>Mark arguments with rigid occurrences of disallowed variables for
--   deletion.</li>
--   <li>Attempt to delete marked arguments.</li>
--   <li>We don't need to check for success, we can just continue occurs
--   checking.</li>
--   </ul>
module Agda.TypeChecking.MetaVars.Occurs
modifyOccursCheckDefs :: (Set QName -> Set QName) -> TCM ()

-- | Set the names of definitions to be looked at to the defs in the
--   current mutual block.
initOccursCheck :: MetaVariable -> TCM ()

-- | Is a def in the list of stuff to be checked?
defNeedsChecking :: QName -> TCM Bool

-- | Remove a def from the list of defs to be looked at.
tallyDef :: QName -> TCM ()

-- | Extra environment for the occurs check. (Complements <a>FreeEnv'</a>.)
data OccursExtra
OccursExtra :: UnfoldStrategy -> VarMap -> MetaId -> Nat -> OccursExtra
[occUnfold] :: OccursExtra -> UnfoldStrategy

-- | The allowed variables with their variance.
[occVars] :: OccursExtra -> VarMap

-- | The meta we want to solve.
[occMeta] :: OccursExtra -> MetaId

-- | The size of the typing context upon invocation.
[occCxtSize] :: OccursExtra -> Nat
type OccursCtx = FreeEnv' () OccursExtra AllowedVar
type OccursM = ReaderT OccursCtx TCM

-- | The passed modality is the one of the current context.
type AllowedVar = Modality -> All

-- | Check whether a free variable is allowed in the context as specified
--   by the modality.
variableCheck :: VarMap -> Maybe Variable -> AllowedVar

-- | Occurs check fails if a defined name is not available since it was
--   declared in irrelevant or erased context.
definitionCheck :: QName -> OccursM ()
metaCheck :: MetaId -> OccursM MetaId

-- | Construct a test whether a de Bruijn index is allowed or needs to be
--   pruned.
allowedVars :: OccursM (Nat -> Bool)

-- | Unfold definitions during occurs check? This effectively runs the
--   occurs check on the normal form.
data UnfoldStrategy
YesUnfold :: UnfoldStrategy
NoUnfold :: UnfoldStrategy
defArgs :: OccursM a -> OccursM a

-- | For a path constructor `c : ... -&gt; Path D a b`, we have that e.g.
--   `c es i0` reduces to <tt>a</tt>. So we have to consider its arguments
--   as flexible when we do not actually unfold.
conArgs :: Elims -> OccursM a -> OccursM a
unfoldB :: (Instantiate t, Reduce t) => t -> OccursM (Blocked t)
unfold :: (Instantiate t, Reduce t) => t -> OccursM t

-- | Leave the strongly rigid position.
weakly :: OccursM a -> OccursM a
strongly :: OccursM a -> OccursM a
flexibly :: OccursM a -> OccursM a
patternViolation' :: MonadTCM m => Blocker -> Int -> String -> m a
abort :: Blocker -> TypeError -> OccursM a

-- | Extended occurs check.
class Occurs t
occurs :: Occurs t => t -> OccursM t
metaOccurs :: Occurs t => MetaId -> t -> TCM ()
metaOccurs :: (Occurs t, Foldable f, Occurs a, f a ~ t) => MetaId -> t -> TCM ()
occurs_ :: (Occurs t, TypeOf t ~ ()) => t -> OccursM t
metaOccurs2 :: (Occurs a, Occurs b) => MetaId -> a -> b -> TCM ()
metaOccurs3 :: (Occurs a, Occurs b, Occurs c) => MetaId -> a -> b -> c -> TCM ()

-- | When assigning <tt>m xs := v</tt>, check that <tt>m</tt> does not
--   occur in <tt>v</tt> and that the free variables of <tt>v</tt> are
--   contained in <tt>xs</tt>.
occursCheck :: MetaId -> VarMap -> Term -> TCM Term
metaOccursQName :: MetaId -> QName -> TCM ()

-- | <tt>prune m' vs xs</tt> attempts to remove all arguments from
--   <tt>vs</tt> whose free variables are not contained in <tt>xs</tt>. If
--   successful, <tt>m'</tt> is solved by the new, pruned meta variable and
--   we return <tt>True</tt> else <tt>False</tt>.
--   
--   Issue 1147: If any of the meta args <tt>vs</tt> is matchable, e.g., is
--   a constructor term, we cannot prune, because the offending variables
--   could be removed by reduction for a suitable instantiation of the meta
--   variable.
prune :: (PureTCM m, MonadMetaSolver m) => MetaId -> Args -> (Nat -> Bool) -> m PruneResult

-- | <tt>hasBadRigid xs v = Just True</tt> iff one of the rigid variables
--   in <tt>v</tt> is not in <tt>xs</tt>. Actually we can only prune if a
--   bad variable is in the head. See issue 458. Or in a non-eliminateable
--   position (see succeed/PruningNonMillerPattern).
--   
--   <tt>hasBadRigid xs v = Nothing</tt> means that we cannot prune at all
--   as one of the meta args is matchable. (See issue 1147.)
hasBadRigid :: PureTCM m => (Nat -> Bool) -> Term -> ExceptT () m Bool

-- | Check whether a term <tt>Def f es</tt> is finally stuck. Currently, we
--   give only a crude approximation.
isNeutral :: HasConstInfo m => Blocked t -> QName -> Elims -> m Bool

-- | Check whether any of the variables (given as de Bruijn indices) occurs
--   *definitely* in the term in a rigid position. Reduces the term
--   successively to remove variables in dead subterms. This fixes issue
--   1386.
rigidVarsNotContainedIn :: (PureTCM m, AnyRigid a) => a -> (Nat -> Bool) -> m Bool

-- | Collect the *definitely* rigid variables in a monoid. We need to
--   successively reduce the expression to do this.
class AnyRigid a
anyRigid :: (AnyRigid a, PureTCM tcm) => (Nat -> tcm Bool) -> a -> tcm Bool
data PruneResult

-- | the kill list is empty or only <tt>False</tt>s
NothingToPrune :: PruneResult

-- | there is no possible kill (because of type dep.)
PrunedNothing :: PruneResult

-- | managed to kill some args in the list
PrunedSomething :: PruneResult

-- | all prescribed kills where performed
PrunedEverything :: PruneResult

-- | <tt>killArgs [k1,...,kn] X</tt> prunes argument <tt>i</tt> from
--   metavar <tt>X</tt> if <tt>ki==True</tt>. Pruning is carried out
--   whenever &gt; 0 arguments can be pruned.
killArgs :: MonadMetaSolver m => [Bool] -> MetaId -> m PruneResult

-- | <tt>killedType [((x1,a1),k1)..((xn,an),kn)] b = ([k'1..k'n],t')</tt>
--   (ignoring <tt>Dom</tt>). Let <tt>t' = (xs:as) -&gt; b</tt>. Invariant:
--   <tt>k'i == True</tt> iff <tt>ki == True</tt> and pruning the
--   <tt>i</tt>th argument from type <tt>b</tt> is possible without
--   creating unbound variables. <tt>t'</tt> is type <tt>t</tt> after
--   pruning all <tt>k'i==True</tt>.
killedType :: MonadReduce m => [(Dom (ArgName, Type), Bool)] -> Type -> m ([Arg Bool], Type)
reallyNotFreeIn :: MonadReduce m => IntSet -> Type -> m (IntSet, Type)

-- | Instantiate a meta variable with a new one that only takes the
--   arguments which are not pruneable.
performKill :: MonadMetaSolver m => [Arg Bool] -> MetaId -> Type -> m ()
instance GHC.Show.Show Agda.TypeChecking.MetaVars.Occurs.UnfoldStrategy
instance GHC.Classes.Eq Agda.TypeChecking.MetaVars.Occurs.UnfoldStrategy
instance GHC.Show.Show Agda.TypeChecking.MetaVars.Occurs.PruneResult
instance GHC.Classes.Eq Agda.TypeChecking.MetaVars.Occurs.PruneResult
instance Agda.TypeChecking.MetaVars.Occurs.Occurs Agda.Syntax.Internal.Term
instance Agda.TypeChecking.MetaVars.Occurs.AnyRigid Agda.Syntax.Internal.Term
instance Agda.TypeChecking.MetaVars.Occurs.AnyRigid Agda.Syntax.Internal.Type
instance Agda.TypeChecking.MetaVars.Occurs.AnyRigid Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.MetaVars.Occurs.AnyRigid Agda.Syntax.Internal.Level
instance Agda.TypeChecking.MetaVars.Occurs.AnyRigid Agda.Syntax.Internal.PlusLevel
instance (Agda.TypeChecking.Substitute.Class.Subst a, Agda.TypeChecking.MetaVars.Occurs.AnyRigid a) => Agda.TypeChecking.MetaVars.Occurs.AnyRigid (Agda.Syntax.Internal.Abs a)
instance Agda.TypeChecking.MetaVars.Occurs.AnyRigid a => Agda.TypeChecking.MetaVars.Occurs.AnyRigid (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.MetaVars.Occurs.AnyRigid a => Agda.TypeChecking.MetaVars.Occurs.AnyRigid (Agda.Syntax.Internal.Dom a)
instance Agda.TypeChecking.MetaVars.Occurs.AnyRigid a => Agda.TypeChecking.MetaVars.Occurs.AnyRigid (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.TypeChecking.MetaVars.Occurs.AnyRigid a => Agda.TypeChecking.MetaVars.Occurs.AnyRigid [a]
instance (Agda.TypeChecking.MetaVars.Occurs.AnyRigid a, Agda.TypeChecking.MetaVars.Occurs.AnyRigid b) => Agda.TypeChecking.MetaVars.Occurs.AnyRigid (a, b)
instance Agda.TypeChecking.MetaVars.Occurs.Occurs Agda.Syntax.Abstract.Name.QName
instance Agda.TypeChecking.MetaVars.Occurs.Occurs Agda.TypeChecking.Monad.Base.Defn
instance Agda.TypeChecking.MetaVars.Occurs.Occurs Agda.Syntax.Internal.Clause
instance Agda.TypeChecking.MetaVars.Occurs.Occurs Agda.Syntax.Internal.Level
instance Agda.TypeChecking.MetaVars.Occurs.Occurs Agda.Syntax.Internal.PlusLevel
instance Agda.TypeChecking.MetaVars.Occurs.Occurs Agda.Syntax.Internal.Type
instance Agda.TypeChecking.MetaVars.Occurs.Occurs Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.MetaVars.Occurs.Occurs Agda.Syntax.Internal.Elims
instance Agda.TypeChecking.MetaVars.Occurs.Occurs (Agda.Syntax.Internal.Abs Agda.Syntax.Internal.Term)
instance Agda.TypeChecking.MetaVars.Occurs.Occurs (Agda.Syntax.Internal.Abs Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.MetaVars.Occurs.Occurs a => Agda.TypeChecking.MetaVars.Occurs.Occurs (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.MetaVars.Occurs.Occurs a => Agda.TypeChecking.MetaVars.Occurs.Occurs (Agda.Syntax.Internal.Dom a)
instance Agda.TypeChecking.Free.Lazy.IsVarSet () Agda.TypeChecking.MetaVars.Occurs.AllowedVar

module Agda.TypeChecking.Lock
isTimeless :: Type -> TCM Bool
checkLockedVars :: Term -> Type -> Arg Term -> Type -> TCM ()
checkEarlierThan :: Term -> VarSet -> TCM ()

module Agda.TypeChecking.MetaVars

-- | Find position of a value in a list. Used to change metavar argument
--   indices during assignment.
--   
--   <tt>reverse</tt> is necessary because we are directly abstracting over
--   the list.
findIdx :: Eq a => [a] -> a -> Maybe Int

-- | Does the given local meta-variable have a twin meta-variable?
hasTwinMeta :: MetaId -> TCM Bool

-- | Check whether a meta variable is a place holder for a blocked term.
isBlockedTerm :: MetaId -> TCM Bool
isEtaExpandable :: [MetaClass] -> MetaId -> TCM Bool

-- | Performing the meta variable assignment.
--   
--   The instantiation should not be an <a>InstV</a> and the <a>MetaId</a>
--   should point to something <a>Open</a> or a <a>BlockedConst</a>.
--   Further, the meta variable may not be <a>Frozen</a>.
assignTerm :: MonadMetaSolver m => MetaId -> [Arg ArgName] -> Term -> m ()

-- | Skip frozen check. Used for eta expanding frozen metas.
assignTermTCM' :: MetaId -> [Arg ArgName] -> Term -> TCM ()

-- | Create a sort meta that cannot be instantiated with <a>Inf</a> (Setω).
newSortMetaBelowInf :: TCM Sort

-- | Create a sort meta that may be instantiated with <a>Inf</a> (Setω).
newSortMeta :: MonadMetaSolver m => m Sort

-- | Create a sort meta that may be instantiated with <a>Inf</a> (Setω).
newSortMetaCtx :: MonadMetaSolver m => Args -> m Sort
newTypeMeta' :: Comparison -> Sort -> TCM Type
newTypeMeta :: Sort -> TCM Type
newTypeMeta_ :: TCM Type
newLevelMeta :: MonadMetaSolver m => m Level

-- | <tt>newInstanceMeta s t cands</tt> creates a new instance metavariable
--   of type the output type of <tt>t</tt> with name suggestion <tt>s</tt>.
newInstanceMeta :: MonadMetaSolver m => MetaNameSuggestion -> Type -> m (MetaId, Term)
newInstanceMetaCtx :: MonadMetaSolver m => MetaNameSuggestion -> Type -> Args -> m (MetaId, Term)

-- | Create a new value meta with specific dependencies, possibly
--   η-expanding in the process.
newNamedValueMeta :: MonadMetaSolver m => RunMetaOccursCheck -> MetaNameSuggestion -> Comparison -> Type -> m (MetaId, Term)

-- | Create a new value meta with specific dependencies without
--   η-expanding.
newNamedValueMeta' :: MonadMetaSolver m => RunMetaOccursCheck -> MetaNameSuggestion -> Comparison -> Type -> m (MetaId, Term)
newValueMetaOfKind :: MonadMetaSolver m => MetaInfo -> RunMetaOccursCheck -> Comparison -> Type -> m (MetaId, Term)

-- | Create a new metavariable, possibly η-expanding in the process.
newValueMeta :: MonadMetaSolver m => RunMetaOccursCheck -> Comparison -> Type -> m (MetaId, Term)
newValueMetaCtx :: MonadMetaSolver m => Frozen -> RunMetaOccursCheck -> Comparison -> Type -> Telescope -> Permutation -> Args -> m (MetaId, Term)

-- | Create a new value meta without η-expanding.
newValueMeta' :: MonadMetaSolver m => RunMetaOccursCheck -> Comparison -> Type -> m (MetaId, Term)
newValueMetaCtx' :: MonadMetaSolver m => Frozen -> RunMetaOccursCheck -> Comparison -> Type -> Telescope -> Permutation -> Args -> m (MetaId, Term)
newTelMeta :: MonadMetaSolver m => Telescope -> m Args
type Condition = Dom Type -> Abs Type -> Bool
trueCondition :: Condition
newArgsMeta :: MonadMetaSolver m => Type -> m Args
newArgsMeta' :: MonadMetaSolver m => Condition -> Type -> m Args
newArgsMetaCtx :: Type -> Telescope -> Permutation -> Args -> TCM Args
newArgsMetaCtx'' :: MonadMetaSolver m => MetaNameSuggestion -> Frozen -> Condition -> Type -> Telescope -> Permutation -> Args -> m Args
newArgsMetaCtx' :: MonadMetaSolver m => Frozen -> Condition -> Type -> Telescope -> Permutation -> Args -> m Args

-- | Create a metavariable of record type. This is actually one
--   metavariable for each field.
newRecordMeta :: QName -> Args -> TCM Term
newRecordMetaCtx :: MetaNameSuggestion -> Frozen -> QName -> Args -> Telescope -> Permutation -> Args -> TCM Term
newQuestionMark :: InteractionId -> Comparison -> Type -> TCM (MetaId, Term)
newQuestionMark' :: (Comparison -> Type -> TCM (MetaId, Term)) -> InteractionId -> Comparison -> Type -> TCM (MetaId, Term)

-- | Construct a blocked constant if there are constraints.
blockTerm :: (MonadMetaSolver m, MonadConstraint m, MonadFresh Nat m, MonadFresh ProblemId m) => Type -> m Term -> m Term
blockTermOnProblem :: (MonadMetaSolver m, MonadFresh Nat m) => Type -> Term -> ProblemId -> m Term
blockTypeOnProblem :: (MonadMetaSolver m, MonadFresh Nat m) => Type -> ProblemId -> m Type

-- | <tt>unblockedTester t</tt> returns a <a>Blocker</a> for <tt>t</tt>.
--   
--   Auxiliary function used when creating a postponed type checking
--   problem.
unblockedTester :: Type -> TCM Blocker

-- | Create a postponed type checking problem <tt>e : t</tt> that waits for
--   type <tt>t</tt> to unblock (become instantiated or its constraints
--   resolved).
postponeTypeCheckingProblem_ :: TypeCheckingProblem -> TCM Term

-- | Create a postponed type checking problem <tt>e : t</tt> that waits for
--   conditon <tt>unblock</tt>. A new meta is created in the current
--   context that has as instantiation the postponed type checking problem.
--   An <a>UnBlock</a> constraint is added for this meta, which links to
--   this meta.
postponeTypeCheckingProblem :: TypeCheckingProblem -> Blocker -> TCM Term

-- | Type of the term that is produced by solving the
--   <a>TypeCheckingProblem</a>.
problemType :: TypeCheckingProblem -> Type

-- | Eta-expand a local meta-variable, if it is of the specified kind.
--   Don't do anything if the meta-variable is a blocked term.
etaExpandMetaTCM :: [MetaClass] -> MetaId -> TCM ()

-- | Eta expand blocking metavariables of record type, and reduce the
--   blocked thing.
etaExpandBlocked :: (MonadReduce m, MonadMetaSolver m, IsMeta t, Reduce t) => Blocked t -> m (Blocked t)
assignWrapper :: (MonadMetaSolver m, MonadConstraint m, MonadError TCErr m, MonadDebug m, HasOptions m) => CompareDirection -> MetaId -> Elims -> Term -> m () -> m ()

-- | Miller pattern unification:
--   
--   <tt>assign dir x vs v a</tt> solves problem <tt>x vs &lt;=(dir) v :
--   a</tt> for meta <tt>x</tt> if <tt>vs</tt> are distinct variables
--   (linearity check) and <tt>v</tt> depends only on these variables and
--   does not contain <tt>x</tt> itself (occurs check).
--   
--   This is the basic story, but we have added some features:
--   
--   <ol>
--   <li>Pruning.</li>
--   <li>Benign cases of non-linearity.</li>
--   <li><tt>vs</tt> may contain record patterns.</li>
--   </ol>
--   
--   For a reference to some of these extensions, read Andreas Abel and
--   Brigitte Pientka's TLCA 2011 paper.
assign :: CompareDirection -> MetaId -> Args -> Term -> CompareAs -> TCM ()

-- | Is the given metavariable application secretly an interaction point
--   application? Ugly.
isInteractionMetaB :: forall m. (ReadTCState m, MonadReduce m, MonadPretty m) => MetaId -> Args -> m (Maybe (MetaId, InteractionId, Args))

-- | <tt>assignMeta m x t ids u</tt> solves <tt>x ids = u</tt> for meta
--   <tt>x</tt> of type <tt>t</tt>, where term <tt>u</tt> lives in a
--   context of length <tt>m</tt>. Precondition: <tt>ids</tt> is linear.
assignMeta :: Int -> MetaId -> Type -> [Int] -> Term -> TCM ()

-- | <tt>assignMeta' m x t ids u</tt> solves <tt>x = [ids]u</tt> for meta
--   <tt>x</tt> of type <tt>t</tt>, where term <tt>u</tt> lives in a
--   context of length <tt>m</tt>, and <tt>ids</tt> is a partial
--   substitution.
assignMeta' :: Int -> MetaId -> Type -> Int -> SubstCand -> Term -> TCM ()

-- | Check that the instantiation of the given metavariable fits the type
--   of the metavariable. If the metavariable is not yet instantiated, add
--   a constraint to check the instantiation later.
checkMetaInst :: MetaId -> TCM ()

-- | Check that the instantiation of the metavariable with the given term
--   is well-typed.
checkSolutionForMeta :: MetaId -> MetaVariable -> Term -> Type -> TCM ()

-- | Given two types <tt>a</tt> and <tt>b</tt> with <tt>a &lt;: b</tt>,
--   check that <tt>a == b</tt>.
checkSubtypeIsEqual :: Type -> Type -> TCM ()

-- | Turn the assignment problem <tt>_X args &lt;= SizeLt u</tt> into
--   <tt>_X args = SizeLt (_Y args)</tt> and constraint <tt>_Y args &lt;=
--   u</tt>.
subtypingForSizeLt :: CompareDirection -> MetaId -> MetaVariable -> Type -> Args -> Term -> (Term -> TCM ()) -> TCM ()

-- | Eta-expand bound variables like <tt>z</tt> in <tt>X (fst z)</tt>.
expandProjectedVars :: (Pretty a, PrettyTCM a, NoProjectedVar a, ReduceAndEtaContract a, PrettyTCM b, TermSubst b) => a -> b -> (a -> b -> TCM c) -> TCM c

-- | Eta-expand a de Bruijn index of record type in context and passed
--   term(s).
etaExpandProjectedVar :: (PrettyTCM a, TermSubst a) => Int -> a -> TCM c -> (a -> TCM c) -> TCM c

-- | Check whether one of the meta args is a projected var.
class NoProjectedVar a
noProjectedVar :: NoProjectedVar a => a -> Either ProjectedVar ()
noProjectedVar :: (NoProjectedVar a, NoProjectedVar b, Foldable t, t b ~ a) => a -> Either ProjectedVar ()

-- | Normalize just far enough to be able to eta-contract maximally.
class (TermLike a, TermSubst a, Reduce a) => ReduceAndEtaContract a
reduceAndEtaContract :: ReduceAndEtaContract a => a -> TCM a
reduceAndEtaContract :: (ReduceAndEtaContract a, Traversable f, TermLike b, Subst b, Reduce b, ReduceAndEtaContract b, f b ~ a) => a -> TCM a
type FVs = VarSet
type SubstCand = -- | a possibly non-deterministic substitution [(Int, Term)]

-- | Turn non-det substitution into proper substitution, if possible.
--   Otherwise, raise the error.
checkLinearity :: SubstCand -> ExceptT () TCM SubstCand
type Res = [(Arg Nat, Term)]

-- | Exceptions raised when substitution cannot be inverted.
data InvertExcept

-- | Cannot recover.
CantInvert :: Term -> InvertExcept

-- | A potentially neutral arg: can't invert, but can try pruning.
NeutralArg :: InvertExcept

-- | Try to eta-expand var to remove projs.
ProjVar :: ProjectedVar -> InvertExcept

-- | Check that arguments <tt>args</tt> to a metavar are in pattern
--   fragment. Assumes all arguments already in whnf and eta-reduced.
--   Parameters are represented as <tt>Var</tt>s so <tt>checkArgs</tt>
--   really checks that all args are <tt>Var</tt>s and returns the
--   "substitution" to be applied to the rhs of the equation to solve. (If
--   <tt>args</tt> is considered a substitution, its inverse is returned.)
--   
--   The returned list might not be ordered. Linearity, i.e., whether the
--   substitution is deterministic, has to be checked separately.
inverseSubst' :: (Term -> Bool) -> Args -> ExceptT InvertExcept TCM SubstCand

-- | If the given metavariable application represents a face, return:
--   
--   <ul>
--   <li>The metavariable information;</li>
--   <li>The actual face, as an assignment of booleans to variables;</li>
--   <li>The substitution candidate resulting from <tt>inverseSubst'</tt>.
--   This is guaranteed to be linear and deterministic.</li>
--   <li>The actual substitution, mapping from the constraint context to
--   the metavariable's context.</li>
--   </ul>
--   
--   Put concisely, a face constraint is an equation in the pattern
--   fragment modulo the presence of endpoints (<tt>i0</tt> and
--   <tt>i1</tt>) in the telescope. In more detail, a face constraint has
--   the form
--   
--   <pre>
--   ?0 Δ (i = i0) (j = i0) Γ (k = i1) Θ (l = i0) = t
--   </pre>
--   
--   where all the greek letters consist entirely of distinct bound
--   variables (and, of course, arbitrarily many endpoints are allowed
--   between each substitution fragment).
isFaceConstraint :: MetaId -> Args -> TCM (Maybe (MetaVariable, IntMap Bool, SubstCand, Substitution))

-- | Record a "face" equation onto an interaction point into the actual
--   interaction point boundary. Takes all the same arguments as
--   <tt>assignMeta'</tt>.
tryAddBoundary :: CompareDirection -> MetaId -> InteractionId -> Args -> Term -> CompareAs -> TCM ()

-- | Turn open metas into postulates.
--   
--   Preconditions:
--   
--   <ol>
--   <li>We are <a>inTopContext</a>.</li>
--   <li><a>envCurrentModule</a> is set to the top-level module.</li>
--   </ol>
openMetasToPostulates :: TCM ()

-- | Sort metas in dependency order.
dependencySortMetas :: [MetaId] -> TCM (Maybe [MetaId])
instance Agda.TypeChecking.MetaVars.ReduceAndEtaContract a => Agda.TypeChecking.MetaVars.ReduceAndEtaContract [a]
instance Agda.TypeChecking.MetaVars.ReduceAndEtaContract a => Agda.TypeChecking.MetaVars.ReduceAndEtaContract (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.MetaVars.ReduceAndEtaContract Agda.Syntax.Internal.Term
instance Agda.TypeChecking.MetaVars.NoProjectedVar a => Agda.TypeChecking.MetaVars.NoProjectedVar (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.MetaVars.NoProjectedVar a => Agda.TypeChecking.MetaVars.NoProjectedVar [a]
instance Agda.TypeChecking.MetaVars.NoProjectedVar Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Monad.MetaVars.MonadMetaSolver Agda.TypeChecking.Monad.Base.TCM


-- | Solving size constraints under hypotheses.
--   
--   The size solver proceeds as follows:
--   
--   <ol>
--   <li>Get size constraints, cluster into connected components.</li>
--   </ol>
--   
--   All size constraints that mention the same metas go into the same
--   cluster. Each cluster can be solved by itself.
--   
--   Constraints that do not fit our format are ignored. We check whether
--   our computed solution fulfills them as well in the last step.
--   
--   <ol>
--   <li>Find a joint context for each cluster.</li>
--   </ol>
--   
--   Each constraint comes with its own typing context, which contains size
--   hypotheses <tt>j : Size&lt; i</tt>. We need to find a common super
--   context in which all constraints of a cluster live, and raise all
--   constraints to this context.
--   
--   There might not be a common super context. Then we are screwed, since
--   our solver is not ready to deal with such a situation. We will
--   blatantly refuse to solve this cluster and blame it on the user.
--   
--   <ol>
--   <li>Convert the joint context into a hypothesis graph.</li>
--   </ol>
--   
--   This is straightforward. Each de Bruijn index becomes a rigid
--   variable, each typing assumption <tt>j : Size&lt; i</tt> becomes an
--   arc.
--   
--   <ol>
--   <li>Convert the constraints into a constraint graph.</li>
--   </ol>
--   
--   Here we need to convert <tt>MetaV</tt>s into flexible variables.
--   
--   <ol>
--   <li>Run the solver</li>
--   <li>Convert the solution into meta instantiations.</li>
--   <li>Double-check whether the constraints are solved.</li>
--   </ol>
module Agda.TypeChecking.SizedTypes.Solve

-- | Flag to control the behavior of size solver.
data DefaultToInfty

-- | Instantiate all unconstrained size variables to ∞.
DefaultToInfty :: DefaultToInfty

-- | Leave unconstrained size variables unsolved.
DontDefaultToInfty :: DefaultToInfty

-- | Solve size constraints involving hypotheses.
solveSizeConstraints :: DefaultToInfty -> TCM ()

-- | TODO: this does not actually work!
--   
--   We would like to use a constraint <tt>c</tt> created in context
--   <tt>Δ</tt> from module <tt>N</tt> in the current context <tt>Γ</tt>
--   and current module <tt>M</tt>.
--   
--   <tt>Δ</tt> is module tel <tt>Δ₁</tt> of <tt>N</tt> extended by some
--   local bindings <tt>Δ₂</tt>. <tt>Γ</tt> is the current context. The
--   module parameter substitution from current <tt>M</tt> to <tt>N</tt> be
--   <tt>Γ ⊢ σ : Δ₁</tt>.
--   
--   If <tt>M == N</tt>, we do not need the parameter substitution. We try
--   raising.
--   
--   We first strengthen <tt>Δ ⊢ c</tt> to live in <tt>Δ₁</tt> and obtain
--   <tt>c₁ = strengthen Δ₂ c</tt>. We then transport <tt>c₁</tt> to
--   <tt>Γ</tt> and obtain <tt>c₂ = applySubst σ c₁</tt>.
--   
--   This works for different modules, but if <tt>M == N</tt> we should not
--   strengthen and then weaken, because strengthening is a partial
--   operation. We should rather lift the substitution <tt>σ</tt> by
--   <tt>Δ₂</tt> and then raise by <tt>Γ₂ - Δ₂</tt>. This "raising" might
--   be a strengthening if <tt>Γ₂</tt> is shorter than <tt>Δ₂</tt>.
--   
--   (TODO: If the module substitution does not exist, because <tt>N</tt>
--   is not a parent of <tt>M</tt>, we cannot use the constraint, as it has
--   been created in an unrelated context.)
castConstraintToCurrentContext' :: Closure Constraint -> MaybeT TCM Constraint

-- | A hazardous hack, may the Gods have mercy on us.
--   
--   To cast to the current context, we match the context of the given
--   constraint by <tt>CtxId</tt>, and as fallback, by variable name
--   (douh!).
--   
--   This hack lets issue 2046 go through.
castConstraintToCurrentContext :: ProblemConstraint -> MaybeT TCM ProblemConstraint

-- | Return the size metas occurring in the simplified constraints. A
--   constraint like <tt>↑ _j =&lt; ∞ : Size</tt> simplifies to nothing, so
--   <tt>_j</tt> would not be in this set.
solveSizeConstraints_ :: DefaultToInfty -> [ProblemConstraint] -> TCM (Set MetaId)

-- | Solve a cluster of constraints sharing some metas.
solveCluster :: DefaultToInfty -> List1 (ProblemConstraint, HypSizeConstraint) -> TCM ()

-- | Collect constraints from a typing context, looking for SIZELT
--   hypotheses.
getSizeHypotheses :: Context -> TCM [(Nat, SizeConstraint)]

-- | Convert size constraint into form where each meta is applied to
--   indices <tt>n-1,...,1,0</tt> where <tt>n</tt> is the arity of that
--   meta.
--   
--   <tt>X[σ] &lt;= t</tt> becomes <tt>X[id] &lt;= t[σ^-1]</tt>
--   
--   <tt>X[σ] ≤ Y[τ]</tt> becomes <tt>X[id] ≤ Y[τ[σ^-1]]</tt> or
--   <tt>X[σ[τ^1]] ≤ Y[id]</tt> whichever is defined. If none is defined,
--   we give up.
--   
--   Cf. <tt>SizedTypes.oldCanonicalizeSizeConstraint</tt>.
--   
--   Fixes (the rather artificial) issue 300. But it is unsound when pruned
--   metas occur and triggers issue 1914. Thus we deactivate it. This needs
--   to be properly implemented, possibly using the metaPermuatation of
--   each meta variable.
canonicalizeSizeConstraint :: SizeConstraint -> Maybe SizeConstraint

-- | Turn a constraint over de Bruijn indices into a size constraint.
computeSizeConstraint :: ProblemConstraint -> TCM (Maybe HypSizeConstraint)

-- | Turn a term into a size expression.
--   
--   Returns <a>Nothing</a> if the term isn't a proper size expression.
sizeExpr :: Term -> TCM (Maybe DBSizeExpr)
instance GHC.Show.Show Agda.TypeChecking.SizedTypes.Solve.DefaultToInfty
instance GHC.Classes.Ord Agda.TypeChecking.SizedTypes.Solve.DefaultToInfty
instance GHC.Classes.Eq Agda.TypeChecking.SizedTypes.Solve.DefaultToInfty
instance Agda.TypeChecking.Substitute.Class.Subst Agda.TypeChecking.SizedTypes.Syntax.SizeMeta
instance Agda.TypeChecking.Substitute.Class.Subst (Agda.TypeChecking.SizedTypes.Syntax.SizeExpr' Agda.TypeChecking.SizedTypes.Syntax.NamedRigid Agda.TypeChecking.SizedTypes.Syntax.SizeMeta)
instance Agda.TypeChecking.Substitute.Class.Subst Agda.TypeChecking.SizedTypes.Syntax.SizeConstraint


-- | SplitClause and CoverResult types.
module Agda.TypeChecking.Coverage.SplitClause
data SplitClause
SClause :: Telescope -> [NamedArg SplitPattern] -> Substitution' SplitPattern -> Map CheckpointId Substitution -> Maybe (Dom Type) -> SplitClause

-- | Type of variables in <tt>scPats</tt>.
[scTel] :: SplitClause -> Telescope

-- | The patterns leading to the currently considered branch of the split
--   tree.
[scPats] :: SplitClause -> [NamedArg SplitPattern]

-- | Substitution from <a>scTel</a> to old context. Only needed directly
--   after split on variable: * To update <a>scTarget</a> * To rename other
--   split variables when splitting on multiple variables. <tt>scSubst</tt>
--   is not `<tt>transitive'</tt>, i.e., does not record the substitution
--   from the original context to <a>scTel</a> over a series of splits. It
--   is freshly computed after each split by <tt>computeNeighborhood</tt>;
--   also <tt>splitResult</tt>, which does not split on a variable, should
--   reset it to the identity <a>idS</a>, lest it be applied to
--   <a>scTarget</a> again, leading to Issue 1294.
[scSubst] :: SplitClause -> Substitution' SplitPattern

-- | We need to keep track of the module parameter checkpoints for the
--   clause for the purpose of inferring missing instance clauses.
[scCheckpoints] :: SplitClause -> Map CheckpointId Substitution

-- | The type of the rhs, living in context <a>scTel</a>.
--   <tt>fixTargetType</tt> computes the new <a>scTarget</a> by applying
--   substitution <a>scSubst</a>.
[scTarget] :: SplitClause -> Maybe (Dom Type)
data UnifyEquiv
UE :: Telescope -> Telescope -> Telescope -> [Term] -> [Term] -> PatternSubstitution -> Substitution -> Substitution -> UnifyEquiv
[infoTel0] :: UnifyEquiv -> Telescope
[infoTel] :: UnifyEquiv -> Telescope
[infoEqTel] :: UnifyEquiv -> Telescope
[infoEqLHS] :: UnifyEquiv -> [Term]
[infoEqRHS] :: UnifyEquiv -> [Term]
[infoRho] :: UnifyEquiv -> PatternSubstitution
[infoTau] :: UnifyEquiv -> Substitution
[infoLeftInv] :: UnifyEquiv -> Substitution
data IInfo
TheInfo :: UnifyEquiv -> IInfo
NoInfo :: IInfo

-- | A <tt>Covering</tt> is the result of splitting a <a>SplitClause</a>.
data Covering
Covering :: Arg Nat -> [(SplitTag, (SplitClause, IInfo))] -> Covering

-- | De Bruijn level (counting dot patterns) of argument we split on.
[covSplitArg] :: Covering -> Arg Nat

-- | Covering clauses, indexed by constructor/literal these clauses share.
[covSplitClauses] :: Covering -> [(SplitTag, (SplitClause, IInfo))]

-- | Project the split clauses out of a covering.
splitClauses :: Covering -> [SplitClause]

-- | Create a split clause from a clause in internal syntax. Used by
--   make-case.
clauseToSplitClause :: Clause -> SplitClause
data CoverResult
CoverResult :: SplitTree -> IntSet -> [(Telescope, [NamedArg DeBruijnPattern])] -> [Clause] -> IntSet -> CoverResult
[coverSplitTree] :: CoverResult -> SplitTree
[coverUsedClauses] :: CoverResult -> IntSet
[coverMissingClauses] :: CoverResult -> [(Telescope, [NamedArg DeBruijnPattern])]

-- | The set of patterns used as cover.
[coverPatterns] :: CoverResult -> [Clause]
[coverNoExactClauses] :: CoverResult -> IntSet
instance GHC.Show.Show Agda.TypeChecking.Coverage.SplitClause.UnifyEquiv
instance GHC.Show.Show Agda.TypeChecking.Coverage.SplitClause.IInfo

module Agda.TypeChecking.Coverage.Cubical
createMissingIndexedClauses :: QName -> Arg Nat -> BlockingVar -> SplitClause -> [(SplitTag, (SplitClause, IInfo))] -> [Clause] -> TCM ([(SplitTag, CoverResult)], [Clause])
covFillTele :: QName -> Abs Telescope -> Term -> Args -> Term -> TCM [Term]
createMissingTrXTrXClause :: QName -> QName -> Arg Nat -> BlockingVar -> SplitClause -> TCM Clause
createMissingTrXHCompClause :: QName -> QName -> Arg Nat -> BlockingVar -> SplitClause -> TCM Clause
createMissingTrXConClause :: QName -> QName -> Arg Nat -> BlockingVar -> SplitClause -> QName -> UnifyEquiv -> TCM Clause

-- | If given <tt>TheInfo{}</tt> then assumes "x : Id u v" and returns both
--   a <tt>SplittingDone</tt> for conId, and the <tt>Clause</tt> that
--   covers it.
createMissingConIdClause :: QName -> Arg Nat -> BlockingVar -> SplitClause -> IInfo -> TCM (Maybe ((SplitTag, SplitTree), Clause))

-- | Append an hcomp clause to the clauses of a function.
createMissingHCompClause :: QName -> Arg Nat -> BlockingVar -> SplitClause -> SplitClause -> [Clause] -> TCM ([(SplitTag, CoverResult)], [Clause])

module Agda.TypeChecking.Conversion
type MonadConversion m = (PureTCM m, MonadConstraint m, MonadMetaSolver m, MonadError TCErr m, MonadWarning m, MonadStatistics m, MonadFresh ProblemId m, MonadFresh Int m, MonadFail m)

-- | Try whether a computation runs without errors or new constraints (may
--   create new metas, though). Restores state upon failure.
tryConversion :: (MonadConstraint m, MonadWarning m, MonadError TCErr m, MonadFresh ProblemId m) => m () -> m Bool

-- | Try whether a computation runs without errors or new constraints (may
--   create new metas, though). Return <a>Just</a> the result upon success.
--   Return <a>Nothing</a> and restore state upon failure.
tryConversion' :: (MonadConstraint m, MonadWarning m, MonadError TCErr m, MonadFresh ProblemId m) => m a -> m (Maybe a)

-- | Check if to lists of arguments are the same (and all variables).
--   Precondition: the lists have the same length.
sameVars :: Elims -> Elims -> Bool

-- | <tt>intersectVars us vs</tt> checks whether all relevant elements in
--   <tt>us</tt> and <tt>vs</tt> are variables, and if yes, returns a prune
--   list which says <tt>True</tt> for arguments which are different and
--   can be pruned.
intersectVars :: Elims -> Elims -> Maybe [Bool]

-- | <tt>guardPointerEquality x y s m</tt> behaves as <tt>m</tt> if
--   <tt>x</tt> and <tt>y</tt> are equal as pointers, or does nothing
--   otherwise. Use with care, see the documentation for
--   <a>unsafeComparePointers</a>
guardPointerEquality :: MonadConversion m => a -> a -> String -> m () -> m ()
equalTerm :: MonadConversion m => Type -> Term -> Term -> m ()
equalAtom :: MonadConversion m => CompareAs -> Term -> Term -> m ()
equalType :: MonadConversion m => Type -> Type -> m ()

-- | Ignore errors in irrelevant context.
convError :: TypeError -> TCM ()

-- | Type directed equality on values.
compareTerm :: forall m. MonadConversion m => Comparison -> Type -> Term -> Term -> m ()

-- | Type directed equality on terms or types.
compareAs :: forall m. MonadConversion m => Comparison -> CompareAs -> Term -> Term -> m ()

-- | Try to assign meta. If meta is projected, try to eta-expand and run
--   conversion check again.
assignE :: MonadConversion m => CompareDirection -> MetaId -> Elims -> Term -> CompareAs -> (Term -> Term -> m ()) -> m ()
compareAsDir :: MonadConversion m => CompareDirection -> CompareAs -> Term -> Term -> m ()
compareAs' :: forall m. MonadConversion m => Comparison -> CompareAs -> Term -> Term -> m ()
compareTerm' :: forall m. MonadConversion m => Comparison -> Type -> Term -> Term -> m ()
compareAtomDir :: MonadConversion m => CompareDirection -> CompareAs -> Term -> Term -> m ()

-- | Compute the head type of an elimination. For projection-like functions
--   this requires inferring the type of the principal argument.
computeElimHeadType :: MonadConversion m => QName -> Elims -> Elims -> m Type

-- | Syntax directed equality on atomic values
compareAtom :: forall m. MonadConversion m => Comparison -> CompareAs -> Term -> Term -> m ()

-- | Check whether <tt>x xArgs <tt>cmp</tt> y yArgs</tt>
compareMetas :: MonadConversion m => Comparison -> CompareAs -> MetaId -> Elims -> MetaId -> Elims -> m ()

-- | Check whether <tt>a1 <tt>cmp</tt> a2</tt> and continue in context
--   extended by <tt>a1</tt>.
compareDom :: (MonadConversion m, Free c) => Comparison -> Dom Type -> Dom Type -> Abs b -> Abs c -> m () -> m () -> m () -> m () -> m () -> m () -> m ()

-- | When comparing argument spines (in compareElims) where the first
--   arguments don't match, we keep going, substituting the
--   anti-unification of the two terms in the telescope. More precisely:
--   
--   @<tt> (u = v : A)[pid] w = antiUnify pid A u v us = vs : Δ[w/x]
--   ------------------------------------------------------------- u us = v
--   vs : (x : A) Δ </tt>@
--   
--   The simplest case of anti-unification is to return a fresh
--   metavariable (created by blockTermOnProblem), but if there's shared
--   structure between the two terms we can expose that.
--   
--   This is really a crutch that lets us get away with things that
--   otherwise would require heterogenous conversion checking. See for
--   instance issue #2384.
antiUnify :: MonadConversion m => ProblemId -> Type -> Term -> Term -> m Term
antiUnifyArgs :: MonadConversion m => ProblemId -> Dom Type -> Arg Term -> Arg Term -> m (Arg Term)
antiUnifyType :: MonadConversion m => ProblemId -> Type -> Type -> m Type
antiUnifyElims :: MonadConversion m => ProblemId -> Type -> Term -> Elims -> Elims -> m Term

-- | <tt>compareElims pols a v els1 els2</tt> performs type-directed
--   equality on eliminator spines. <tt>t</tt> is the type of the head
--   <tt>v</tt>.
compareElims :: forall m. MonadConversion m => [Polarity] -> [IsForced] -> Type -> Term -> [Elim] -> [Elim] -> m ()

-- | <a>Compare</a> two terms in irrelevant position. This always succeeds.
--   However, we can dig for solutions of irrelevant metas in the terms we
--   compare. (Certainly not the systematic solution, that'd be proof
--   search...)
compareIrrelevant :: MonadConversion m => Type -> Term -> Term -> m ()
compareWithPol :: MonadConversion m => Polarity -> (Comparison -> a -> a -> m ()) -> a -> a -> m ()
polFromCmp :: Comparison -> Polarity

-- | Type-directed equality on argument lists
compareArgs :: MonadConversion m => [Polarity] -> [IsForced] -> Type -> Term -> Args -> Args -> m ()

-- | Equality on Types
compareType :: MonadConversion m => Comparison -> Type -> Type -> m ()
leqType :: MonadConversion m => Type -> Type -> m ()

-- | <tt>coerce v a b</tt> coerces <tt>v : a</tt> to type <tt>b</tt>,
--   returning a <tt>v' : b</tt> with maybe extra hidden applications or
--   hidden abstractions.
--   
--   In principle, this function can host coercive subtyping, but currently
--   it only tries to fix problems with hidden function types.
coerce :: (MonadConversion m, MonadTCM m) => Comparison -> Term -> Type -> Type -> m Term

-- | Account for situations like <tt>k : (Size&lt; j) &lt;= (Size&lt; k +
--   1)</tt>
--   
--   Actually, the semantics is <tt>(Size&lt;= k) ∩ (Size&lt; j) ⊆ rhs</tt>
--   which gives a disjunctive constraint. Mmmh, looks like stuff TODO.
--   
--   For now, we do a cheap heuristics.
coerceSize :: MonadConversion m => (Type -> Type -> m ()) -> Term -> Type -> Type -> m ()
compareLevel :: MonadConversion m => Comparison -> Level -> Level -> m ()
compareSort :: MonadConversion m => Comparison -> Sort -> Sort -> m ()

-- | Check that the first sort is less or equal to the second.
--   
--   We can put <tt>SizeUniv</tt> below <tt>Inf</tt>, but otherwise, it is
--   unrelated to the other universes.
leqSort :: forall m. MonadConversion m => Sort -> Sort -> m ()
leqLevel :: MonadConversion m => Level -> Level -> m ()
equalLevel :: forall m. MonadConversion m => Level -> Level -> m ()

-- | Check that the first sort equal to the second.
equalSort :: forall m. MonadConversion m => Sort -> Sort -> m ()
forallFaceMaps :: MonadConversion m => Term -> (IntMap Bool -> Blocker -> Term -> m a) -> (IntMap Bool -> Substitution -> m a) -> m [a]
compareInterval :: MonadConversion m => Comparison -> Type -> Term -> Term -> m ()
type Conj = (IntMap BoolSet, [Term])
isCanonical :: [Conj] -> Bool

-- | leqInterval r q = r ≤ q in the I lattice. (∨ r_i) ≤ (∨ q_j) iff ∀ i. ∃
--   j. r_i ≤ q_j
leqInterval :: MonadConversion m => [Conj] -> [Conj] -> m Bool

-- | leqConj r q = r ≤ q in the I lattice, when r and q are conjuctions. '
--   (∧ r_i) ≤ (∧ q_j) iff ' (∧ r_i) ∧ (∧ q_j) = (∧ r_i) iff ' {r_i | i} ∪
--   {q_j | j} = {r_i | i} iff ' {q_j | j} ⊆ {r_i | i}
leqConj :: MonadConversion m => Conj -> Conj -> m Bool

-- | equalTermOnFace φ A u v = _ , φ ⊢ u = v : A
equalTermOnFace :: MonadConversion m => Term -> Type -> Term -> Term -> m ()
compareTermOnFace :: MonadConversion m => Comparison -> Term -> Type -> Term -> Term -> m ()
compareTermOnFace' :: MonadConversion m => (Substitution -> Comparison -> Type -> Term -> Term -> m ()) -> Comparison -> Term -> Type -> Term -> Term -> m ()
bothAbsurd :: MonadConversion m => QName -> QName -> m Bool


-- | Checking local or global confluence of rewrite rules.
--   
--   For checking LOCAL CONFLUENCE of a given rewrite rule <tt>f ps ↦
--   v</tt>, we construct critical pairs involving this as the main rule by
--   searching for:
--   
--   <ol>
--   <li>*Different* rules <tt>f ps' ↦ v'</tt> where <tt>ps</tt> and
--   <tt>ps'</tt> can be unified@.</li>
--   <li>Subpatterns <tt>g qs</tt> of <tt>ps</tt> and rewrite rules <tt>g
--   qs' ↦ w</tt> where <tt>qs</tt> and <tt>qs'</tt> can be unified.</li>
--   </ol>
--   
--   Each of these leads to a *critical pair* <tt>v₁ <a>u --</a> v₂</tt>,
--   which should satisfy <tt>v₁ = v₂</tt>.
--   
--   For checking GLOBAL CONFLUENCE, we check the following two properties:
--   
--   <ol>
--   <li>For any two left-hand sides of the rewrite rules that overlap
--   (either at the root position or at a subterm), the most general
--   unifier of the two left-hand sides is again a left-hand side of a
--   rewrite rule. For example, if there are two rules <tt>suc m + n = suc
--   (m + n)</tt> and <tt>m + suc n = suc (m + n)</tt>, then there should
--   also be a rule <tt>suc m + suc n = suc (suc (m + n))</tt>.</li>
--   <li>Each rewrite rule should satisfy the *triangle property*: For any
--   rewrite rule <tt>u = w</tt> and any single-step parallel unfolding
--   <tt>u =&gt; v</tt>, we should have another single-step parallel
--   unfolding <tt>v =&gt; w</tt>.</li>
--   </ol>
module Agda.TypeChecking.Rewriting.Confluence
checkConfluenceOfRules :: ConfluenceCheck -> [RewriteRule] -> TCM ()

-- | Check confluence of the given rewrite rules wrt all other rewrite
--   rules (also amongst themselves).
--   
--   Check confluence of the clauses of the given function wrt rewrite
--   rules of the constructors they match against
checkConfluenceOfClauses :: ConfluenceCheck -> QName -> TCM ()
sortRulesOfSymbol :: QName -> TCM ()
instance GHC.Base.Functor Agda.TypeChecking.Rewriting.Confluence.OneHole
instance Agda.TypeChecking.Rewriting.Confluence.MetasToVars a => Agda.TypeChecking.Rewriting.Confluence.MetasToVars [a]
instance Agda.TypeChecking.Rewriting.Confluence.MetasToVars a => Agda.TypeChecking.Rewriting.Confluence.MetasToVars (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Rewriting.Confluence.MetasToVars a => Agda.TypeChecking.Rewriting.Confluence.MetasToVars (Agda.Syntax.Internal.Dom a)
instance Agda.TypeChecking.Rewriting.Confluence.MetasToVars a => Agda.TypeChecking.Rewriting.Confluence.MetasToVars (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.TypeChecking.Rewriting.Confluence.MetasToVars a => Agda.TypeChecking.Rewriting.Confluence.MetasToVars (Agda.Syntax.Internal.Abs a)
instance Agda.TypeChecking.Rewriting.Confluence.MetasToVars Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Rewriting.Confluence.MetasToVars Agda.Syntax.Internal.Type
instance Agda.TypeChecking.Rewriting.Confluence.MetasToVars Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Rewriting.Confluence.MetasToVars Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Rewriting.Confluence.MetasToVars Agda.Syntax.Internal.PlusLevel
instance Agda.TypeChecking.Rewriting.Confluence.MetasToVars a => Agda.TypeChecking.Rewriting.Confluence.MetasToVars (Agda.Syntax.Internal.Tele a)
instance (Agda.TypeChecking.Rewriting.Confluence.MetasToVars a, Agda.TypeChecking.Rewriting.Confluence.MetasToVars b) => Agda.TypeChecking.Rewriting.Confluence.MetasToVars (a, b)
instance (Agda.TypeChecking.Rewriting.Confluence.MetasToVars a, Agda.TypeChecking.Rewriting.Confluence.MetasToVars b, Agda.TypeChecking.Rewriting.Confluence.MetasToVars c) => Agda.TypeChecking.Rewriting.Confluence.MetasToVars (a, b, c)
instance (Agda.TypeChecking.Rewriting.Confluence.MetasToVars a, Agda.TypeChecking.Rewriting.Confluence.MetasToVars b, Agda.TypeChecking.Rewriting.Confluence.MetasToVars c, Agda.TypeChecking.Rewriting.Confluence.MetasToVars d) => Agda.TypeChecking.Rewriting.Confluence.MetasToVars (a, b, c, d)
instance Agda.TypeChecking.Rewriting.Confluence.AllHoles p => Agda.TypeChecking.Rewriting.Confluence.AllHoles (Agda.Syntax.Common.Arg p)
instance Agda.TypeChecking.Rewriting.Confluence.AllHoles p => Agda.TypeChecking.Rewriting.Confluence.AllHoles (Agda.Syntax.Internal.Dom p)
instance Agda.TypeChecking.Rewriting.Confluence.AllHoles (Agda.Syntax.Internal.Abs Agda.Syntax.Internal.Term)
instance Agda.TypeChecking.Rewriting.Confluence.AllHoles (Agda.Syntax.Internal.Abs Agda.Syntax.Internal.Type)
instance Agda.TypeChecking.Rewriting.Confluence.AllHoles Agda.Syntax.Internal.Elims
instance Agda.TypeChecking.Rewriting.Confluence.AllHoles Agda.Syntax.Internal.Type
instance Agda.TypeChecking.Rewriting.Confluence.AllHoles Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Rewriting.Confluence.AllHoles Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Rewriting.Confluence.AllHoles Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Rewriting.Confluence.AllHoles [Agda.Syntax.Internal.PlusLevel]
instance Agda.TypeChecking.Rewriting.Confluence.AllHoles Agda.Syntax.Internal.PlusLevel
instance Agda.TypeChecking.Rewriting.Confluence.ParallelReduce Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Rewriting.Confluence.ParallelReduce Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Rewriting.Confluence.ParallelReduce a => Agda.TypeChecking.Rewriting.Confluence.ParallelReduce (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Rewriting.Confluence.ParallelReduce a => Agda.TypeChecking.Rewriting.Confluence.ParallelReduce (Agda.Syntax.Internal.Dom a)
instance Agda.TypeChecking.Rewriting.Confluence.ParallelReduce a => Agda.TypeChecking.Rewriting.Confluence.ParallelReduce (Agda.Syntax.Internal.Type' a)
instance Agda.TypeChecking.Rewriting.Confluence.ParallelReduce a => Agda.TypeChecking.Rewriting.Confluence.ParallelReduce [a]
instance Agda.TypeChecking.Rewriting.Confluence.ParallelReduce a => Agda.TypeChecking.Rewriting.Confluence.ParallelReduce (Agda.Syntax.Internal.Elim.Elim' a)
instance (Agda.TypeChecking.Free.Lazy.Free a, Agda.TypeChecking.Substitute.Class.Subst a, Agda.TypeChecking.Rewriting.Confluence.ParallelReduce a) => Agda.TypeChecking.Rewriting.Confluence.ParallelReduce (Agda.Syntax.Internal.Abs a)


-- | Rewriting with arbitrary rules.
--   
--   The user specifies a relation symbol by the pragma <tt> {-# BUILTIN
--   REWRITE rel #-} </tt> where <tt>rel</tt> should be of type <tt>Δ →
--   (lhs rhs : A) → Set i</tt>.
--   
--   Then the user can add rewrite rules by the pragma <tt> {-# REWRITE q
--   #-} </tt> where <tt>q</tt> should be a closed term of type <tt>Γ → rel
--   us lhs rhs</tt>.
--   
--   We then intend to add a rewrite rule <tt> Γ ⊢ lhs ↦ rhs : B </tt> to
--   the signature where <tt>B = A[us/Δ]</tt>.
--   
--   To this end, we normalize <tt>lhs</tt>, which should be of the form
--   <tt> f ts </tt> for a <tt><a>Def</a></tt>-symbol f (postulate,
--   function, data, record, constructor). Further, <tt>FV(ts) =
--   dom(Γ)</tt>. The rule <tt>q :: Γ ⊢ f ts ↦ rhs : B</tt> is added to the
--   signature to the definition of <tt>f</tt>.
--   
--   When reducing a term <tt>Ψ ⊢ f vs</tt> is stuck, we try the rewrites
--   for <tt>f</tt>, by trying to unify <tt>vs</tt> with <tt>ts</tt>. This
--   is for now done by substituting fresh metas Xs for the bound variables
--   in <tt>ts</tt> and checking equality with <tt>vs</tt> <tt> Ψ ⊢ (f
--   ts)[Xs<i>Γ] = f vs : B[Xs</i>Γ] </tt> If successful (no open
--   metas/constraints), we replace <tt>f vs</tt> by <tt>rhs[Xs/Γ]</tt> and
--   continue reducing.
module Agda.TypeChecking.Rewriting
requireOptionRewriting :: TCM ()

-- | Check that the name given to the BUILTIN REWRITE is actually a
--   relation symbol. I.e., its type should be of the form <tt>Δ → (lhs :
--   A) (rhs : B) → Set ℓ</tt>. Note: we do not care about
--   hiding/non-hiding of lhs and rhs.
verifyBuiltinRewrite :: Term -> Type -> TCM ()

-- | Deconstructing a type into <tt>Δ → t → t' → core</tt>.
data RelView
RelView :: Telescope -> ListTel -> Dom Type -> Dom Type -> Type -> RelView

-- | The whole telescope <tt>Δ, t, t'</tt>.
[relViewTel] :: RelView -> Telescope

-- | <tt>Δ</tt>.
[relViewDelta] :: RelView -> ListTel

-- | <tt>t</tt>.
[relViewType] :: RelView -> Dom Type

-- | <tt>t'</tt>.
[relViewType'] :: RelView -> Dom Type

-- | <tt>core</tt>.
[relViewCore] :: RelView -> Type

-- | Deconstructing a type into <tt>Δ → t → t' → core</tt>. Returns
--   <tt>Nothing</tt> if not enough argument types.
relView :: Type -> TCM (Maybe RelView)

-- | Check the given rewrite rules and add them to the signature.
addRewriteRules :: [QName] -> TCM ()

-- | Get domain of rewrite relation.
rewriteRelationDom :: QName -> TCM (ListTel, Dom Type)

-- | Check the validity of <tt>q : Γ → rel us lhs rhs</tt> as rewrite rule
--   <tt> Γ ⊢ lhs ↦ rhs : B </tt> where <tt>B = A[us/Δ]</tt>. Remember that
--   <tt>rel : Δ → A → A → Set i</tt>, so <tt>rel us : (lhs rhs : A[us/Δ])
--   → Set i</tt>. Returns the checked rewrite rule to be added to the
--   signature.
checkRewriteRule :: QName -> TCM (Maybe RewriteRule)

-- | <tt>rewriteWith t f es rew</tt> where <tt>f : t</tt> tries to rewrite
--   <tt>f es</tt> with <tt>rew</tt>, returning the reduct if successful.
rewriteWith :: Type -> (Elims -> Term) -> RewriteRule -> Elims -> ReduceM (Either (Blocked Term) Term)

-- | <tt>rewrite b v rules es</tt> tries to rewrite <tt>v</tt> applied to
--   <tt>es</tt> with the rewrite rules <tt>rules</tt>. <tt>b</tt> is the
--   default blocking tag.
rewrite :: Blocked_ -> (Elims -> Term) -> RewriteRules -> Elims -> ReduceM (Reduced (Blocked Term) Term)


-- | This module implements the Agda Abstract Machine used for compile-time
--   reduction. It's a call-by-need environment machine with an implicit
--   heap maintained using <a>STRef</a>s. See the <a>AM</a> type below for
--   a description of the machine.
--   
--   Some other tricks that improves performance:
--   
--   <ul>
--   <li>Memoise getConstInfo.</li>
--   </ul>
--   
--   A big chunk of the time during reduction is spent looking up
--   definitions in the signature. Any long-running reduction will use only
--   a handful definitions though, so memoising getConstInfo is a big win.
--   
--   <ul>
--   <li>Optimised case trees.</li>
--   </ul>
--   
--   Since we memoise getConstInfo we can do some preprocessing of the
--   definitions, returning a <a>CompactDef</a> instead of a
--   <a>Definition</a>. In particular we streamline the case trees used for
--   matching in a few ways:
--   
--   <ul>
--   <li>Drop constructor arity information.</li>
--   <li>Use NameId instead of QName as map keys.</li>
--   <li>Special branch for natural number successor.</li>
--   </ul>
--   
--   None of these changes would make sense to incorporate into the actual
--   case trees. The first two loses information that we need in other
--   places and the third would complicate a lot of code working with case
--   trees.
--   
--   <a>CompactDef</a> also has a special representation for
--   built-in/primitive functions that can be implemented as pure functions
--   from <a>Literal</a>s.
module Agda.TypeChecking.Reduce.Fast

-- | The entry point to the reduction machine.
fastReduce :: Term -> ReduceM (Blocked Term)
fastNormalise :: Term -> ReduceM Term
instance GHC.Classes.Eq Agda.TypeChecking.Reduce.Fast.Normalisation
instance GHC.Base.Functor Agda.TypeChecking.Reduce.Fast.Thunk
instance Data.Traversable.Traversable Agda.TypeChecking.Reduce.Fast.ElimZipper
instance Data.Foldable.Foldable Agda.TypeChecking.Reduce.Fast.ElimZipper
instance GHC.Base.Functor Agda.TypeChecking.Reduce.Fast.ElimZipper
instance GHC.Show.Show a => GHC.Show.Show (Agda.TypeChecking.Reduce.Fast.ElimZipper a)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Agda.TypeChecking.Reduce.Fast.ElimZipper a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Agda.TypeChecking.Reduce.Fast.ElimZipper a)
instance Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.Reduce.Fast.AM s)
instance Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.Reduce.Fast.ControlFrame s)
instance Agda.Utils.Zipper.Zipper (Agda.TypeChecking.Reduce.Fast.ElimZipper a)
instance Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.Reduce.Fast.MatchStack s)
instance Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.Reduce.Fast.CatchAllFrame s)
instance Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.Reduce.Fast.Pointer s)
instance Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.Reduce.Fast.Closure s)
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.Reduce.Fast.Thunk a)
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.Reduce.Fast.FastCompiledClauses
instance Agda.Syntax.Common.Pretty.Pretty a => Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.Reduce.Fast.FastCase a)

module Agda.TypeChecking.Modalities

-- | The second argument is the definition of the first.
checkModality' :: MonadConversion m => QName -> Definition -> m (Maybe TypeError)

-- | The second argument is the definition of the first.
checkModality :: MonadConversion m => QName -> Definition -> m ()

-- | Checks that the given implicitely inserted arguments, are used in a
--   modally correct way.
checkModalityArgs :: MonadConversion m => Definition -> Args -> m ()

module Agda.TypeChecking.IApplyConfluence
checkIApplyConfluence_ :: QName -> TCM ()

-- | <tt>checkIApplyConfluence f (Clause {namedClausePats = ps})</tt>
--   checks that <tt>f ps</tt> reduces in a way that agrees with
--   <tt>IApply</tt> reductions.
checkIApplyConfluence :: QName -> Clause -> TCM ()

-- | current context is of the form Γ.Δ
unifyElims :: Args -> Args -> (Substitution -> [(Term, Term)] -> TCM a) -> TCM a

-- | Like <tt>unifyElims</tt> but <tt>Γ</tt> is from the meta's
--   <tt>MetaInfo</tt> and the context extension <tt>Δ</tt> is taken from
--   the <tt>Closure</tt>.
unifyElimsMeta :: MetaId -> Args -> Closure Constraint -> ([(Term, Term)] -> Constraint -> TCM a) -> TCM a


-- | This module implements the type checking part of generalisable
--   variables. When we get here we have a type checking problem for a type
--   (or telescope) containing a known set of generalisable variables and
--   we need to produce a well typed type (or telescope) with the correct
--   generalisations. For instance, given
--   
--   <pre>
--   variable
--     A  : Set
--     n  : Nat
--     xs : Vec A n
--   
--   foo : SomeType xs
--   </pre>
--   
--   generalisation should produce <tt>{A : Set} {n : Nat} {xs : Vec A n} →
--   SomeType xs</tt> for the type of <tt>foo</tt>.
--   
--   The functions <a>generalizeType</a> and <a>generalizeTelescope</a>
--   don't have access to the abstract syntax to be type checked
--   (<tt>SomeType xs</tt> in the example). Instead they are provided a
--   type checking action that delivers a <a>Type</a> or a
--   <a>Telescope</a>. The challenge is setting up a context in which
--   <tt>SomeType xs</tt> can be type checked successfully by this action,
--   without knowing what the telescope of generalised variables will be.
--   Once we have computed this telescope the result needs to be
--   transformed into a well typed type abstracted over it.
--   
--   <b>At no point are we allowed to cheat!</b> Any transformation between
--   well typed terms needs to be done by well typed substitutions.
--   
--   The key idea is to run the type checking action in the context of a
--   single variable of an unknown type. Once we know what variables to
--   generalise over this type is instantiated to a fresh record type with
--   a field for each generalised variable. Turning the result of action
--   into something valid in the context of the generalised variables is
--   then a simple substitution unpacking the record variable.
--   
--   In more detail, generalisation proceeds as follows:
--   
--   <ul>
--   <li>Add a variable <tt>genTel</tt> of an unknown type to the context
--   (<a>withGenRecVar</a>).</li>
--   </ul>
--   
--   <pre>
--   (genTel : _GenTel)
--   </pre>
--   
--   <ul>
--   <li>Create metavariables for the generalisable variables appearing in
--   the problem and their dependencies (<a>createGenValues</a>). In the
--   example this would be</li>
--   </ul>
--   
--   <pre>
--   (genTel : _GenTel) ⊢
--     _A  : Set
--     _n  : Nat
--     _xs : Vec _A _n
--   </pre>
--   
--   <ul>
--   <li>Run the type checking action (<a>createMetasAndTypeCheck</a>),
--   binding the mentioned generalisable variables to the corresponding
--   newly created metavariables. This binding is stored in
--   <a>eGeneralizedVars</a> and picked up in <a>inferDef</a></li>
--   </ul>
--   
--   <pre>
--   (genTel : _GenTel) ⊢ SomeType (_xs genTel)
--   </pre>
--   
--   <ul>
--   <li>Compute the telescope of generalised variables
--   (<a>computeGeneralization</a>). This is done by taking the
--   unconstrained metavariables created by <a>createGenValues</a> or
--   created during the type checking action and sorting them into a well
--   formed telescope.</li>
--   </ul>
--   
--   <pre>
--   {A : Set} {n : Nat} {xs : Vec A n}
--   </pre>
--   
--   <ul>
--   <li>Create a record type <tt>GeneralizeTel</tt> whose fields are the
--   generalised variables and instantiate the type of <tt>genTel</tt> to
--   it (<a>createGenRecordType</a>).</li>
--   </ul>
--   
--   <pre>
--   record GeneralizeTel : Set₁ where
--     constructor mkGeneralizeTel
--     field
--       A  : Set
--       n  : Nat
--       xs : Vec A n
--   </pre>
--   
--   <ul>
--   <li>Solve the metavariables with their corresponding projections from
--   <tt>genTel</tt>.</li>
--   </ul>
--   
--   <pre>
--   _A  := λ genTel → genTel .A
--   _n  := λ genTel → genTel .n
--   _xs := λ genTel → genTel .xs
--   </pre>
--   
--   <ul>
--   <li>Build the unpacking substitution (<a>unpackSub</a>) that maps
--   terms in <tt>(genTel : GeneralizeTel)</tt> to terms in the context of
--   the generalised variables by substituting a record value for
--   <tt>genTel</tt>.</li>
--   </ul>
--   
--   <pre>
--   {A : Set} {n : Nat} {xs : Vec A n} ⊢ [mkGeneralizeTel A n xs / genTel] : (genTel : GeneralizeTel)
--   </pre>
--   
--   <ul>
--   <li>Build the final result by applying the unpacking substitution to
--   the result of the type checking action and abstracting over the
--   generalised telescope.</li>
--   </ul>
--   
--   <pre>
--   {A : Set} {n : Nat} {xs : Vec A n} → SomeType (_xs (mkGeneralizeTel A n xs)) ==
--   {A : Set} {n : Nat} {xs : Vec A n} → SomeType xs
--   </pre>
--   
--   <ul>
--   <li>In case of <a>generalizeType</a> return the resulting pi
--   type.</li>
--   <li>In case of <a>generalizeTelescope</a> enter the resulting context,
--   applying the unpacking substitution to let bindings (TODO #6916: and
--   also module applications!) created in the telescope, and call the
--   continuation.</li>
--   </ul>
module Agda.TypeChecking.Generalize

-- | Generalize a type over a set of (used) generalizable variables.
generalizeType :: Set QName -> TCM Type -> TCM ([Maybe QName], Type)

-- | Allow returning additional information from the type checking action.
generalizeType' :: Set QName -> TCM (Type, a) -> TCM ([Maybe QName], Type, a)

-- | Generalize a telescope over a set of generalizable variables.
generalizeTelescope :: Map QName Name -> (forall a. (Telescope -> TCM a) -> TCM a) -> ([Maybe Name] -> Telescope -> TCM a) -> TCM a

module Agda.TypeChecking.Rules.Data

-- | Type check a datatype definition. Assumes that the type has already
--   been checked.
checkDataDef :: DefInfo -> QName -> UniverseCheck -> DataDefParams -> [Constructor] -> TCM ()

-- | Make sure that the target universe admits data type definitions. E.g.
--   <tt>IUniv</tt>, <tt>SizeUniv</tt> etc. do not accept new
--   constructions.
checkDataSort :: QName -> Sort -> TCM ()

-- | Ensure that the type is a sort. If it is not directly a sort, compare
--   it to a <a>newSortMetaBelowInf</a>.
forceSort :: Type -> TCM Sort

-- | Type check a constructor declaration. Checks that the constructor
--   targets the datatype and that it fits inside the declared sort.
--   Returns the non-linear parameters.
checkConstructor :: QName -> UniverseCheck -> Telescope -> Nat -> Sort -> Constructor -> TCM IsPathCons
defineCompData :: QName -> ConHead -> Telescope -> [QName] -> Telescope -> Type -> Boundary -> TCM CompKit

-- | Define projections for non-indexed data types (families don't work
--   yet). Of course, these projections are partial functions in general.
--   
--   Precondition: we are in the context Γ of the data type parameters.
defineProjections :: QName -> ConHead -> Telescope -> [QName] -> Telescope -> Type -> TCM ()
freshAbstractQName'_ :: String -> TCM QName

-- | Defines and returns the name of the <tt>transpIx</tt> function.
defineTranspIx :: QName -> TCM (Maybe QName)
defineTranspFun :: QName -> Maybe QName -> [QName] -> [QName] -> TCM (Maybe QName)
defineConClause :: QName -> Bool -> Maybe QName -> Nat -> Nat -> Telescope -> Telescope -> Substitution -> Type -> [QName] -> TCM [Clause]
defineKanOperationForFields :: Command -> Maybe Term -> (Term -> QName -> Term) -> QName -> Telescope -> Telescope -> [Arg QName] -> Type -> TCM (Maybe ((QName, Telescope, Type, [Dom Type], [Term]), Substitution))
defineTranspForFields :: Maybe Term -> (Term -> QName -> Term) -> QName -> Telescope -> Tele (Dom CType) -> [Arg QName] -> Type -> TCM ((QName, Telescope, Type, [Dom Type], [Term]), Substitution)
defineHCompForFields :: (Term -> QName -> Term) -> QName -> Telescope -> Tele (Dom LType) -> [Arg QName] -> LType -> TCM ((QName, Telescope, Type, [Dom Type], [Term]), Substitution)
getGeneralizedParameters :: Set Name -> QName -> TCM [Maybe Name]

-- | Bind the named generalized parameters.
bindGeneralizedParameters :: [Maybe Name] -> Type -> (Telescope -> Type -> TCM a) -> TCM a

-- | Bind the parameters of a datatype.
--   
--   We allow omission of hidden parameters at the definition site.
--   Example: <tt> data D {a} (A : Set a) : Set a data D A where c : A
--   -&gt; D A </tt>
bindParameters :: Int -> [LamBinding] -> Type -> (Telescope -> Type -> TCM a) -> TCM a
bindParameter :: Int -> [LamBinding] -> Name -> Dom Type -> Abs Type -> (Telescope -> Type -> TCM a) -> TCM a

-- | Check that the arguments to a constructor fits inside the sort of the
--   datatype. The third argument is the type of the constructor.
--   
--   When <tt>--without-K</tt> is active and the type is fibrant the
--   procedure also checks that the type is usable at the current modality.
--   See #4784 and #5434.
--   
--   As a side effect, return the arity of the constructor.
fitsIn :: QName -> UniverseCheck -> [IsForced] -> Type -> Sort -> TCM Int

-- | When --without-K is enabled, we should check that the sorts of the
--   index types fit into the sort of the datatype.
checkIndexSorts :: Sort -> Telescope -> TCM ()

-- | Return the parameters that share variables with the indices
--   nonLinearParameters :: Int -&gt; Type -&gt; TCM [Int]
--   nonLinearParameters nPars t =
data IsPathCons
PathCons :: IsPathCons
PointCons :: IsPathCons

-- | Check that a type constructs something of the given datatype. The
--   first argument is the number of parameters to the datatype and the
--   second the number of additional non-parameters in the context (1 when
--   generalizing, 0 otherwise).
constructs :: Int -> Int -> Type -> QName -> TCM IsPathCons

-- | Is the type coinductive? Returns <a>Nothing</a> if the answer cannot
--   be determined.
isCoinductive :: Type -> TCM (Maybe Bool)
instance GHC.Show.Show Agda.TypeChecking.Rules.Data.IsPathCons
instance GHC.Classes.Eq Agda.TypeChecking.Rules.Data.IsPathCons


-- | A bidirectional type checker for internal syntax.
--   
--   Performs checking on unreduced terms. With the exception that
--   projection-like function applications have to be reduced since they
--   break bidirectionality.
module Agda.TypeChecking.CheckInternal
type MonadCheckInternal m = MonadConversion m

-- | Entry point for e.g. checking WithFunctionType.
checkType :: MonadCheckInternal m => Type -> m ()

-- | Infer type of a neutral term.
infer :: MonadCheckInternal m => Term -> m Type

-- | <tt>inferSpine action t hd es</tt> checks that spine <tt>es</tt>
--   eliminates value <tt>hd []</tt> of type <tt>t</tt> and returns the
--   remaining type (target of elimination) and the transformed
--   eliminations.
inferSpine :: MonadCheckInternal m => Action m -> Type -> (Elims -> Term) -> Elims -> m (Type, Elims)
class CheckInternal a
checkInternal' :: (CheckInternal a, MonadCheckInternal m) => Action m -> a -> Comparison -> TypeOf a -> m a
checkInternal :: (CheckInternal a, MonadCheckInternal m) => a -> Comparison -> TypeOf a -> m ()
inferInternal' :: (CheckInternal a, MonadCheckInternal m, TypeOf a ~ ()) => Action m -> a -> m a
inferInternal :: (CheckInternal a, MonadCheckInternal m, TypeOf a ~ ()) => a -> m ()

-- | <a>checkInternal</a> traverses the whole <a>Term</a>, and we can use
--   this traversal to modify the term.
data Action m
Action :: (Type -> Term -> m Term) -> (Type -> Term -> m Term) -> (Modality -> Modality -> Modality) -> (Term -> m Term) -> Action m

-- | Called on each subterm before the checker runs.
[preAction] :: Action m -> Type -> Term -> m Term

-- | Called on each subterm after the type checking.
[postAction] :: Action m -> Type -> Term -> m Term

-- | Called for each <tt>ArgInfo</tt>. The first <a>Modality</a> is from
--   the type, the second from the term.
[modalityAction] :: Action m -> Modality -> Modality -> Modality

-- | Called for bringing projection-like funs in post-fix form
[elimViewAction] :: Action m -> Term -> m Term

-- | The default action is to not change the <a>Term</a> at all.
defaultAction :: PureTCM m => Action m
eraseUnusedAction :: Action TCM
instance Agda.TypeChecking.CheckInternal.CheckInternal Agda.Syntax.Internal.Type
instance Agda.TypeChecking.CheckInternal.CheckInternal Agda.Syntax.Internal.Term
instance Agda.TypeChecking.CheckInternal.CheckInternal Agda.Syntax.Internal.Elims
instance Agda.TypeChecking.CheckInternal.CheckInternal Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.CheckInternal.CheckInternal Agda.Syntax.Internal.Level
instance Agda.TypeChecking.CheckInternal.CheckInternal Agda.Syntax.Internal.PlusLevel


-- | Reconstruct dropped parameters from constructors. Used by
--   with-abstraction to avoid ill-typed abstractions (#745). Note that the
--   term is invalid after parameter reconstruction. Parameters need to be
--   dropped again before using it.
module Agda.TypeChecking.ReconstructParameters
reconstructParametersInType :: Type -> TCM Type
reconstructParametersInType' :: Action TCM -> Type -> TCM Type
reconstructParametersInTel :: Telescope -> TCM Telescope
reconstructParametersInEqView :: EqualityView -> TCM EqualityView
reconstructParameters :: Type -> Term -> TCM Term
reconstructParameters' :: Action TCM -> Type -> Term -> TCM Term
reconstructAction :: Action TCM
reconstructAction' :: Action TCM -> Action TCM
reconstruct :: Type -> Term -> TCM Term
extractParameters :: QName -> Type -> TCM Args
dropParameters :: TermLike a => a -> TCM a

module Agda.TypeChecking.Unquote
agdaTermType :: TCM Type
agdaTypeType :: TCM Type
qNameType :: TCM Type
data Dirty
Dirty :: Dirty
Clean :: Dirty
type UnquoteState = (Dirty, TCState)
type UnquoteM = ReaderT Context (StateT UnquoteState (WriterT [QName] (ExceptT UnquoteError TCM)))
type UnquoteRes a = Either UnquoteError ((a, UnquoteState), [QName])
unpackUnquoteM :: UnquoteM a -> Context -> UnquoteState -> TCM (UnquoteRes a)
packUnquoteM :: (Context -> UnquoteState -> TCM (UnquoteRes a)) -> UnquoteM a
runUnquoteM :: UnquoteM a -> TCM (Either UnquoteError (a, [QName]))
liftU1 :: (TCM (UnquoteRes a) -> TCM (UnquoteRes b)) -> UnquoteM a -> UnquoteM b
liftU2 :: (TCM (UnquoteRes a) -> TCM (UnquoteRes b) -> TCM (UnquoteRes c)) -> UnquoteM a -> UnquoteM b -> UnquoteM c
inOriginalContext :: UnquoteM a -> UnquoteM a
isCon :: ConHead -> TCM (Maybe Term) -> UnquoteM Bool
isDef :: QName -> TCM (Maybe Term) -> UnquoteM Bool
reduceQuotedTerm :: Term -> UnquoteM Term
class Unquote a
unquote :: Unquote a => Term -> UnquoteM a
unquoteN :: Unquote a => Arg Term -> UnquoteM a
choice :: Monad m => [(m Bool, m a)] -> m a -> m a
ensureDef :: QName -> UnquoteM QName
ensureCon :: QName -> UnquoteM QName
pickName :: Type -> String
unquoteString :: Term -> UnquoteM String
unquoteNString :: Arg Term -> UnquoteM Text
data ErrorPart
StrPart :: String -> ErrorPart
TermPart :: Expr -> ErrorPart
PattPart :: Pattern -> ErrorPart
NamePart :: QName -> ErrorPart

-- | We do a little bit of work here to make it possible to generate nice
--   layout for multi-line error messages. Specifically we split the parts
--   into lines (indicated by n in a string part) and vcat all the lines.
renderErrorParts :: [ErrorPart] -> TCM Doc

-- | Argument should be a term of type <tt>Term → TCM A</tt> for some A.
--   Returns the resulting term of type <tt>A</tt>. The second argument is
--   the term for the hole, which will typically be a metavariable. This is
--   passed to the computation (quoted).
unquoteTCM :: Term -> Term -> UnquoteM Term
evalTCM :: Term -> UnquoteM Term
type ExeArg = Text
type StdIn = Text
type StdOut = Text
type StdErr = Text

-- | Raise an error if the <tt>--allow-exec</tt> option was not specified.
requireAllowExec :: TCM ()

-- | Convert an <tt>ExitCode</tt> to an Agda natural number.
exitCodeToNat :: ExitCode -> Nat

-- | Call a trusted executable with the given arguments and input.
--   
--   Returns the exit code, stdout, and stderr.
tcExec :: ExeName -> [ExeArg] -> StdIn -> TCM Term

-- | Raise an error if the trusted executable cannot be found.
raiseExeNotTrusted :: ExeName -> Map ExeName FilePath -> TCM a
raiseExeNotFound :: ExeName -> FilePath -> TCM a
raiseExeNotExecutable :: ExeName -> FilePath -> TCM a
instance GHC.Classes.Eq Agda.TypeChecking.Unquote.Dirty
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Unquote.ErrorPart
instance Agda.TypeChecking.Unquote.Unquote Agda.TypeChecking.Unquote.ErrorPart
instance Agda.TypeChecking.Unquote.Unquote Agda.Syntax.Common.Modality
instance Agda.TypeChecking.Unquote.Unquote Agda.Syntax.Common.ArgInfo
instance Agda.TypeChecking.Unquote.Unquote a => Agda.TypeChecking.Unquote.Unquote (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Unquote.Unquote Agda.Syntax.Reflected.Elim
instance Agda.TypeChecking.Unquote.Unquote GHC.Types.Bool
instance Agda.TypeChecking.Unquote.Unquote GHC.Num.Integer.Integer
instance Agda.TypeChecking.Unquote.Unquote GHC.Word.Word64
instance Agda.TypeChecking.Unquote.Unquote GHC.Types.Double
instance Agda.TypeChecking.Unquote.Unquote GHC.Types.Char
instance Agda.TypeChecking.Unquote.Unquote Data.Text.Internal.Text
instance Agda.TypeChecking.Unquote.Unquote a => Agda.TypeChecking.Unquote.Unquote [a]
instance (Agda.TypeChecking.Unquote.Unquote a, Agda.TypeChecking.Unquote.Unquote b) => Agda.TypeChecking.Unquote.Unquote (a, b)
instance Agda.TypeChecking.Unquote.Unquote Agda.Syntax.Common.Hiding
instance Agda.TypeChecking.Unquote.Unquote Agda.Syntax.Common.Relevance
instance Agda.TypeChecking.Unquote.Unquote Agda.Syntax.Common.Quantity
instance Agda.TypeChecking.Unquote.Unquote Agda.Syntax.Abstract.Name.QName
instance Agda.TypeChecking.Unquote.Unquote a => Agda.TypeChecking.Unquote.Unquote (Agda.Syntax.Reflected.Abs a)
instance Agda.TypeChecking.Unquote.Unquote Agda.Syntax.Internal.Blockers.Blocker
instance Agda.TypeChecking.Unquote.Unquote Agda.Syntax.Common.MetaId
instance Agda.TypeChecking.Unquote.Unquote a => Agda.TypeChecking.Unquote.Unquote (Agda.Syntax.Internal.Dom a)
instance Agda.TypeChecking.Unquote.Unquote Agda.Syntax.Reflected.Sort
instance Agda.TypeChecking.Unquote.Unquote Agda.Syntax.Literal.Literal
instance Agda.TypeChecking.Unquote.Unquote Agda.Syntax.Reflected.Term
instance Agda.TypeChecking.Unquote.Unquote Agda.Syntax.Reflected.Pattern
instance Agda.TypeChecking.Unquote.Unquote Agda.Syntax.Reflected.Clause


-- | Functions for abstracting terms over other terms.
module Agda.TypeChecking.Abstract

-- | <tt>abstractType a v b[v] = b</tt> where <tt>a : v</tt>.
abstractType :: Type -> Term -> Type -> TCM Type

-- | <tt>piAbstractTerm NotHidden v a b[v] = (w : a) -&gt; b[w]</tt>
--   <tt>piAbstractTerm Hidden v a b[v] = {w : a} -&gt; b[w]</tt>
piAbstractTerm :: ArgInfo -> Term -> Type -> Type -> TCM Type

-- | <pre>
--   piAbstract (v, a) b[v] = (w : a) -&gt; b[w]
--   </pre>
--   
--   For the inspect idiom, it does something special: @piAbstract (v, a)
--   b[v] = (w : a) {w' : Eq a w v} -&gt; b[w]
--   
--   For <tt>rewrite</tt>, it does something special: <tt>piAbstract (prf,
--   Eq a v v') b[v,prf] = (w : a) (w' : Eq a w v') -&gt; b[w,w']</tt>
piAbstract :: Arg (Term, EqualityView) -> Type -> TCM Type

-- | <tt>isPrefixOf u v = Just es</tt> if <tt>v == u <a>applyE</a> es</tt>.
class IsPrefixOf a
isPrefixOf :: IsPrefixOf a => a -> a -> Maybe Elims
abstractTerm :: Type -> Term -> Type -> Term -> TCM Term
class AbsTerm a

-- | <pre>
--   subst u . absTerm u == id
--   </pre>
absTerm :: AbsTerm a => Term -> a -> a

-- | This swaps <tt>var 0</tt> and <tt>var 1</tt>.
swap01 :: TermSubst a => a -> a
class EqualSy a
equalSy :: EqualSy a => a -> a -> Bool
instance Agda.TypeChecking.Abstract.IsPrefixOf Agda.Syntax.Internal.Elims
instance Agda.TypeChecking.Abstract.IsPrefixOf Agda.Syntax.Internal.Args
instance Agda.TypeChecking.Abstract.IsPrefixOf Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Abstract.EqualSy a => Agda.TypeChecking.Abstract.EqualSy [a]
instance Agda.TypeChecking.Abstract.EqualSy Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Abstract.EqualSy Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Abstract.EqualSy Agda.Syntax.Internal.PlusLevel
instance Agda.TypeChecking.Abstract.EqualSy Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Abstract.EqualSy Agda.Syntax.Internal.Type
instance Agda.TypeChecking.Abstract.EqualSy a => Agda.TypeChecking.Abstract.EqualSy (Agda.Syntax.Internal.Elim.Elim' a)
instance (Agda.TypeChecking.Substitute.Class.Subst a, Agda.TypeChecking.Abstract.EqualSy a) => Agda.TypeChecking.Abstract.EqualSy (Agda.Syntax.Internal.Abs a)
instance Agda.TypeChecking.Abstract.EqualSy Agda.Syntax.Common.ArgInfo
instance Agda.TypeChecking.Abstract.EqualSy a => Agda.TypeChecking.Abstract.EqualSy (Agda.Syntax.Internal.Dom a)
instance Agda.TypeChecking.Abstract.EqualSy a => Agda.TypeChecking.Abstract.EqualSy (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Abstract.AbsTerm Agda.Syntax.Internal.Term
instance Agda.TypeChecking.Abstract.AbsTerm Agda.Syntax.Internal.Type
instance Agda.TypeChecking.Abstract.AbsTerm Agda.Syntax.Internal.Sort
instance Agda.TypeChecking.Abstract.AbsTerm Agda.Syntax.Internal.Level
instance Agda.TypeChecking.Abstract.AbsTerm Agda.Syntax.Internal.PlusLevel
instance Agda.TypeChecking.Abstract.AbsTerm a => Agda.TypeChecking.Abstract.AbsTerm (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.TypeChecking.Abstract.AbsTerm a => Agda.TypeChecking.Abstract.AbsTerm (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Abstract.AbsTerm a => Agda.TypeChecking.Abstract.AbsTerm (Agda.Syntax.Internal.Dom a)
instance Agda.TypeChecking.Abstract.AbsTerm a => Agda.TypeChecking.Abstract.AbsTerm [a]
instance Agda.TypeChecking.Abstract.AbsTerm a => Agda.TypeChecking.Abstract.AbsTerm (GHC.Maybe.Maybe a)
instance (Agda.TypeChecking.Substitute.Class.TermSubst a, Agda.TypeChecking.Abstract.AbsTerm a) => Agda.TypeChecking.Abstract.AbsTerm (Agda.Syntax.Internal.Abs a)
instance (Agda.TypeChecking.Abstract.AbsTerm a, Agda.TypeChecking.Abstract.AbsTerm b) => Agda.TypeChecking.Abstract.AbsTerm (a, b)

module Agda.TypeChecking.With

-- | Split pattern variables according to with-expressions.
splitTelForWith :: Telescope -> Type -> [Arg (Term, EqualityView)] -> (Telescope, Telescope, Permutation, Type, [Arg (Term, EqualityView)])

-- | Abstract with-expressions <tt>vs</tt> to generate type for with-helper
--   function.
--   
--   Each <tt>EqualityType</tt>, coming from a <tt>rewrite</tt>, will turn
--   into 2 abstractions.
withFunctionType :: Telescope -> [Arg (Term, EqualityView)] -> Telescope -> Type -> [(Int, (Term, Term))] -> TCM (Type, Nat)
countWithArgs :: [EqualityView] -> Nat

-- | From a list of <tt>with</tt> and <tt>rewrite</tt> expressions and
--   their types, compute the list of final <tt>with</tt> expressions
--   (after expanding the <tt>rewrite</tt>s).
withArguments :: [Arg (Term, EqualityView)] -> TCM [Arg Term]

-- | Compute the clauses for the with-function given the original patterns.
buildWithFunction :: [Name] -> QName -> QName -> Type -> Telescope -> [NamedArg DeBruijnPattern] -> Nat -> Substitution -> Permutation -> Nat -> Nat -> List1 SpineClause -> TCM (List1 SpineClause)

-- | <pre>
--   stripWithClausePatterns cxtNames parent f t Δ qs np π ps = ps'
--   </pre>
--   
--   Example:
--   
--   <pre>
--   record Stream (A : Set) : Set where
--     coinductive
--     constructor delay
--     field       force : A × Stream A
--   
--   record SEq (s t : Stream A) : Set where
--     coinductive
--     field
--       ~force : let a , as = force s
--                    b , bs = force t
--                in  a ≡ b × SEq as bs
--   
--   test : (s : Nat × Stream Nat) (t : Stream Nat) → SEq (delay s) t → SEq t (delay s)
--   ~force (test (a     , as) t p) with force t
--   ~force (test (suc n , as) t p) | b , bs = ?
--   </pre>
--   
--   With function:
--   
--   <pre>
--   f : (t : Stream Nat) (w : Nat × Stream Nat) (a : Nat) (as : Stream Nat)
--       (p : SEq (delay (a , as)) t) → (fst w ≡ a) × SEq (snd w) as
--   
--   Δ  = t a as p   -- reorder to bring with-relevant (= needed) vars first
--   π  = a as t p → Δ
--   qs = (a     , as) t p ~force
--   ps = (suc n , as) t p ~force
--   ps' = (suc n) as t p
--   </pre>
--   
--   Resulting with-function clause is:
--   
--   <pre>
--   f t (b , bs) (suc n) as t p
--   </pre>
--   
--   Note: stripWithClausePatterns factors <b><tt>ps</tt></b> through
--   <b><tt>qs</tt></b>, thus
--   
--   <pre>
--   ps = qs[ps']
--   </pre>
--   
--   where <tt>[..]</tt> is to be understood as substitution. The
--   projection patterns have vanished from <b><tt>ps'</tt></b> (as they
--   are already in <b><tt>qs</tt></b>).
stripWithClausePatterns :: [Name] -> QName -> QName -> Type -> Telescope -> [NamedArg DeBruijnPattern] -> Nat -> Permutation -> [NamedArg Pattern] -> TCM ([ProblemEq], [NamedArg Pattern])

-- | Construct the display form for a with function. It will display
--   applications of the with function as applications to the original
--   function. For instance,
--   
--   <pre>
--   aux a b c
--   
--   </pre>
--   
--   as
--   
--   <pre>
--   f (suc a) (suc b) | c
--   
--   </pre>
withDisplayForm :: QName -> QName -> Telescope -> Telescope -> Nat -> [NamedArg DeBruijnPattern] -> Permutation -> Permutation -> TCM DisplayForm
patsToElims :: [NamedArg DeBruijnPattern] -> [Elim' DisplayTerm]

module Agda.Termination.TermCheck

-- | Entry point: Termination check a single declaration.
--   
--   Precondition: <a>envMutualBlock</a> must be set correctly.
termDecl :: Declaration -> TCM Result

-- | Entry point: Termination check the current mutual block.
termMutual :: [QName] -> TCM Result

-- | The result of termination checking a module. Must be a <a>Monoid</a>
--   and have <a>Singleton</a>.
type Result = [TerminationError]
instance Agda.Termination.TermCheck.StripAllProjections a => Agda.Termination.TermCheck.StripAllProjections (Agda.Syntax.Common.Arg a)
instance Agda.Termination.TermCheck.StripAllProjections Agda.Syntax.Internal.Elims
instance Agda.Termination.TermCheck.StripAllProjections Agda.Syntax.Internal.Args
instance Agda.Termination.TermCheck.StripAllProjections Agda.Syntax.Internal.Term
instance Agda.Termination.TermCheck.ExtractCalls a => Agda.Termination.TermCheck.ExtractCalls (Agda.Syntax.Internal.Abs a)
instance Agda.Termination.TermCheck.ExtractCalls a => Agda.Termination.TermCheck.ExtractCalls (Agda.Syntax.Common.Arg a)
instance Agda.Termination.TermCheck.ExtractCalls a => Agda.Termination.TermCheck.ExtractCalls (Agda.Syntax.Internal.Dom a)
instance Agda.Termination.TermCheck.ExtractCalls a => Agda.Termination.TermCheck.ExtractCalls (Agda.Syntax.Internal.Elim.Elim' a)
instance Agda.Termination.TermCheck.ExtractCalls a => Agda.Termination.TermCheck.ExtractCalls [a]
instance (Agda.Termination.TermCheck.ExtractCalls a, Agda.Termination.TermCheck.ExtractCalls b) => Agda.Termination.TermCheck.ExtractCalls (a, b)
instance (Agda.Termination.TermCheck.ExtractCalls a, Agda.Termination.TermCheck.ExtractCalls b, Agda.Termination.TermCheck.ExtractCalls c) => Agda.Termination.TermCheck.ExtractCalls (a, b, c)
instance Agda.Termination.TermCheck.ExtractCalls Agda.Syntax.Internal.Sort
instance Agda.Termination.TermCheck.ExtractCalls Agda.Syntax.Internal.Type
instance Agda.Termination.TermCheck.ExtractCalls a => Agda.Termination.TermCheck.ExtractCalls (Agda.Syntax.Internal.Tele a)
instance Agda.Termination.TermCheck.ExtractCalls Agda.Syntax.Internal.Term
instance Agda.Termination.TermCheck.ExtractCalls Agda.Syntax.Internal.Level
instance Agda.Termination.TermCheck.ExtractCalls Agda.Syntax.Internal.PlusLevel
instance Agda.Termination.TermCheck.TermToPattern a b => Agda.Termination.TermCheck.TermToPattern [a] [b]
instance Agda.Termination.TermCheck.TermToPattern a b => Agda.Termination.TermCheck.TermToPattern (Agda.Syntax.Common.Arg a) (Agda.Syntax.Common.Arg b)
instance Agda.Termination.TermCheck.TermToPattern a b => Agda.Termination.TermCheck.TermToPattern (Agda.Syntax.Common.Named c a) (Agda.Syntax.Common.Named c b)
instance Agda.Termination.TermCheck.TermToPattern Agda.Syntax.Internal.Term Agda.Syntax.Internal.DeBruijnPattern


-- | Sanity checking for internal syntax. Mostly checking variable scoping.
module Agda.Syntax.Internal.SanityCheck
sanityCheckVars :: (Pretty a, Free a) => Telescope -> a -> TCM ()

-- | Check that <tt>Γ ⊢ ρ : Δ</tt>.
sanityCheckSubst :: (Pretty a, Free a) => Telescope -> Substitution' a -> Telescope -> TCM ()

module Agda.Syntax.IdiomBrackets
parseIdiomBracketsSeq :: Range -> [Expr] -> ScopeM Expr


-- | Desugaring for do-notation. Uses whatever `_&gt;&gt;=_` and
--   `_&gt;&gt;_` happen to be in scope.
--   
--   Example:
--   
--   ``` foo = do x ← m₁ m₂ just y ← m₃ where nothing → m₄ let z = t m₅ ```
--   desugars to ``` foo = m₁ &gt;&gt;= λ x → m₂ &gt;&gt; m₃ &gt;&gt;= λ
--   where just y → let z = t in m₅ nothing → m₄ ```
module Agda.Syntax.DoNotation
desugarDoNotation :: Range -> List1 DoStmt -> ScopeM Expr

module Agda.Interaction.Monad

-- | Interaction monad.
data IM a
runIM :: IM a -> TCM a

-- | Line reader. The line reader history is not stored between sessions.
readline :: String -> IM (Maybe String)
instance Agda.TypeChecking.Monad.Base.MonadTCM Agda.Interaction.Monad.IM
instance Agda.TypeChecking.Monad.Base.MonadTCState Agda.Interaction.Monad.IM
instance Agda.TypeChecking.Monad.Base.ReadTCState Agda.Interaction.Monad.IM
instance Agda.TypeChecking.Monad.Base.MonadTCEnv Agda.Interaction.Monad.IM
instance Agda.Interaction.Options.HasOptions.HasOptions Agda.Interaction.Monad.IM
instance Control.Monad.IO.Class.MonadIO Agda.Interaction.Monad.IM
instance GHC.Base.Monad Agda.Interaction.Monad.IM
instance GHC.Base.Applicative Agda.Interaction.Monad.IM
instance GHC.Base.Functor Agda.Interaction.Monad.IM
instance Control.Monad.Error.Class.MonadError Agda.TypeChecking.Monad.Base.TCErr Agda.Interaction.Monad.IM


-- | Encoding stuff into JSON values in TCM
module Agda.Interaction.JSON

-- | A type-level indicator that <tt>ToJSON1</tt> or <tt>FromJSON1</tt> is
--   being derived generically.
data () => One

-- | A type that can be converted from JSON, with the possibility of
--   failure.
--   
--   In many cases, you can get the compiler to generate parsing code for
--   you (see below). To begin, let's cover writing an instance by hand.
--   
--   There are various reasons a conversion could fail. For example, an
--   <a>Object</a> could be missing a required key, an <a>Array</a> could
--   be of the wrong size, or a value could be of an incompatible type.
--   
--   The basic ways to signal a failed conversion are as follows:
--   
--   <ul>
--   <li><a>fail</a> yields a custom error message: it is the recommended
--   way of reporting a failure;</li>
--   <li><a>empty</a> (or <a>mzero</a>) is uninformative: use it when the
--   error is meant to be caught by some <tt>(<a>&lt;|&gt;</a>)</tt>;</li>
--   <li><a>typeMismatch</a> can be used to report a failure when the
--   encountered value is not of the expected JSON type; <a>unexpected</a>
--   is an appropriate alternative when more than one type may be expected,
--   or to keep the expected type implicit.</li>
--   </ul>
--   
--   <a>prependFailure</a> (or <a>modifyFailure</a>) add more information
--   to a parser's error messages.
--   
--   An example type and instance using <a>typeMismatch</a> and
--   <a>prependFailure</a>:
--   
--   <pre>
--   -- Allow ourselves to write <a>Text</a> literals.
--   {-# LANGUAGE OverloadedStrings #-}
--   
--   data Coord = Coord { x :: Double, y :: Double }
--   
--   instance <a>FromJSON</a> Coord where
--       <a>parseJSON</a> (<a>Object</a> v) = Coord
--           <a>&lt;$&gt;</a> v <a>.:</a> "x"
--           <a>&lt;*&gt;</a> v <a>.:</a> "y"
--   
--       -- We do not expect a non-<a>Object</a> value here.
--       -- We could use <a>empty</a> to fail, but <a>typeMismatch</a>
--       -- gives a much more informative error message.
--       <a>parseJSON</a> invalid    =
--           <a>prependFailure</a> "parsing Coord failed, "
--               (<a>typeMismatch</a> "Object" invalid)
--   </pre>
--   
--   For this common case of only being concerned with a single type of
--   JSON value, the functions <a>withObject</a>, <a>withScientific</a>,
--   etc. are provided. Their use is to be preferred when possible, since
--   they are more terse. Using <a>withObject</a>, we can rewrite the above
--   instance (assuming the same language extension and data type) as:
--   
--   <pre>
--   instance <a>FromJSON</a> Coord where
--       <a>parseJSON</a> = <a>withObject</a> "Coord" $ \v -&gt; Coord
--           <a>&lt;$&gt;</a> v <a>.:</a> "x"
--           <a>&lt;*&gt;</a> v <a>.:</a> "y"
--   </pre>
--   
--   Instead of manually writing your <a>FromJSON</a> instance, there are
--   two options to do it automatically:
--   
--   <ul>
--   <li><a>Data.Aeson.TH</a> provides Template Haskell functions which
--   will derive an instance at compile time. The generated instance is
--   optimized for your type so it will probably be more efficient than the
--   following option.</li>
--   <li>The compiler can provide a default generic implementation for
--   <a>parseJSON</a>.</li>
--   </ul>
--   
--   To use the second, simply add a <tt>deriving <a>Generic</a></tt>
--   clause to your datatype and declare a <a>FromJSON</a> instance for
--   your datatype without giving a definition for <a>parseJSON</a>.
--   
--   For example, the previous example can be simplified to just:
--   
--   <pre>
--   {-# LANGUAGE DeriveGeneric #-}
--   
--   import <a>GHC.Generics</a>
--   
--   data Coord = Coord { x :: Double, y :: Double } deriving <a>Generic</a>
--   
--   instance <a>FromJSON</a> Coord
--   </pre>
--   
--   or using the <a>DerivingVia extension</a>
--   
--   <pre>
--   deriving via <a>Generically</a> Coord instance <a>FromJSON</a> Coord
--   </pre>
--   
--   The default implementation will be equivalent to <tt>parseJSON =
--   <a>genericParseJSON</a> <a>defaultOptions</a></tt>; if you need
--   different options, you can customize the generic decoding by defining:
--   
--   <pre>
--   customOptions = <a>defaultOptions</a>
--                   { <a>fieldLabelModifier</a> = <a>map</a> <a>toUpper</a>
--                   }
--   
--   instance <a>FromJSON</a> Coord where
--       <a>parseJSON</a> = <a>genericParseJSON</a> customOptions
--   </pre>
class () => FromJSON a
parseJSON :: FromJSON a => Value -> Parser a
parseJSONList :: FromJSON a => Value -> Parser [a]

-- | Default value for optional fields. Used by <tt>(<a>.:?=</a>)</tt>
--   operator, and Generics and TH deriving with
--   <tt><a>allowOmittedFields</a> = True</tt> (default).
omittedField :: FromJSON a => Maybe a

-- | A JSON "object" (key/value map).
type Object = KeyMap Value

-- | A JSON "array" (sequence).
type Array = Vector Value

-- | Lifting of the <a>FromJSON</a> class to unary type constructors.
--   
--   Instead of manually writing your <a>FromJSON1</a> instance, there are
--   two options to do it automatically:
--   
--   <ul>
--   <li><a>Data.Aeson.TH</a> provides Template Haskell functions which
--   will derive an instance at compile time. The generated instance is
--   optimized for your type so it will probably be more efficient than the
--   following option.</li>
--   <li>The compiler can provide a default generic implementation for
--   <a>liftParseJSON</a>.</li>
--   </ul>
--   
--   To use the second, simply add a <tt>deriving <a>Generic1</a></tt>
--   clause to your datatype and declare a <a>FromJSON1</a> instance for
--   your datatype without giving a definition for <a>liftParseJSON</a>.
--   
--   For example:
--   
--   <pre>
--   {-# LANGUAGE DeriveGeneric #-}
--   
--   import <a>GHC.Generics</a>
--   
--   data Pair a b = Pair { pairFst :: a, pairSnd :: b } deriving <a>Generic1</a>
--   
--   instance <a>FromJSON</a> a =&gt; <a>FromJSON1</a> (Pair a)
--   </pre>
--   
--   or
--   
--   <pre>
--   deriving via <a>Generically1</a> (Pair a) instance <a>FromJSON1</a> (Pair a)
--   </pre>
--   
--   If the default implementation doesn't give exactly the results you
--   want, you can customize the generic decoding with only a tiny amount
--   of effort, using <a>genericLiftParseJSON</a> with your preferred
--   <a>Options</a>:
--   
--   <pre>
--   customOptions = <a>defaultOptions</a>
--                   { <a>fieldLabelModifier</a> = <a>map</a> <a>toUpper</a>
--                   }
--   
--   instance <a>FromJSON</a> a =&gt; <a>FromJSON1</a> (Pair a) where
--       <a>liftParseJSON</a> = <a>genericLiftParseJSON</a> customOptions
--   </pre>
class () => FromJSON1 (f :: Type -> Type)
liftParseJSON :: FromJSON1 f => Maybe a -> (Value -> Parser a) -> (Value -> Parser [a]) -> Value -> Parser (f a)
liftParseJSONList :: FromJSON1 f => Maybe a -> (Value -> Parser a) -> (Value -> Parser [a]) -> Value -> Parser [f a]
liftOmittedField :: FromJSON1 f => Maybe a -> Maybe (f a)
data () => Key

-- | A type-level indicator that <tt>ToJSON</tt> or <tt>FromJSON</tt> is
--   being derived generically.
data () => Zero

-- | Exception thrown by <tt>throwDecode</tt> and variants.
newtype () => AesonException
AesonException :: String -> AesonException

-- | Options for encoding keys with <a>genericFromJSONKey</a> and
--   <a>genericToJSONKey</a>.
data () => JSONKeyOptions

-- | Specifies how to encode constructors of a sum datatype.
data () => SumEncoding

-- | A constructor will be encoded to an object with a field
--   <a>tagFieldName</a> which specifies the constructor tag (modified by
--   the <a>constructorTagModifier</a>). If the constructor is a record the
--   encoded record fields will be unpacked into this object. So make sure
--   that your record doesn't have a field with the same label as the
--   <a>tagFieldName</a>. Otherwise the tag gets overwritten by the encoded
--   value of that field! If the constructor is not a record the encoded
--   constructor contents will be stored under the <a>contentsFieldName</a>
--   field.
TaggedObject :: String -> String -> SumEncoding
[tagFieldName] :: SumEncoding -> String
[contentsFieldName] :: SumEncoding -> String

-- | Constructor names won't be encoded. Instead only the contents of the
--   constructor will be encoded as if the type had a single constructor.
--   JSON encodings have to be disjoint for decoding to work properly.
--   
--   When decoding, constructors are tried in the order of definition. If
--   some encodings overlap, the first one defined will succeed.
--   
--   <i>Note:</i> Nullary constructors are encoded as strings (using
--   <a>constructorTagModifier</a>). Having a nullary constructor alongside
--   a single field constructor that encodes to a string leads to
--   ambiguity.
--   
--   <i>Note:</i> Only the last error is kept when decoding, so in the case
--   of malformed JSON, only an error for the last constructor will be
--   reported.
UntaggedValue :: SumEncoding

-- | A constructor will be encoded to an object with a single field named
--   after the constructor tag (modified by the
--   <a>constructorTagModifier</a>) which maps to the encoded contents of
--   the constructor.
ObjectWithSingleField :: SumEncoding

-- | A constructor will be encoded to a 2-element array where the first
--   element is the tag of the constructor (modified by the
--   <a>constructorTagModifier</a>) and the second element the encoded
--   contents of the constructor.
TwoElemArray :: SumEncoding

-- | Options that specify how to encode/decode your datatype to/from JSON.
--   
--   Options can be set using record syntax on <a>defaultOptions</a> with
--   the fields below.
data () => Options

-- | A newtype wrapper for <a>UTCTime</a> that uses the same non-standard
--   serialization format as Microsoft .NET, whose <a>System.DateTime</a>
--   type is by default serialized to JSON as in the following example:
--   
--   <pre>
--   /Date(1302547608878)/
--   </pre>
--   
--   The number represents milliseconds since the Unix epoch.
newtype () => DotNetTime
DotNetTime :: UTCTime -> DotNetTime

-- | Acquire the underlying value.
[fromDotNetTime] :: DotNetTime -> UTCTime

-- | A JSON value represented as a Haskell value.
data () => Value
Object :: !Object -> Value
Array :: !Array -> Value
String :: !Text -> Value
Number :: !Scientific -> Value
Bool :: !Bool -> Value
Null :: Value
type JSONPath = [JSONPathElement]

-- | A series of values that, when encoded, should be separated by commas.
--   Since 0.11.0.0, the <tt>.=</tt> operator is overloaded to create
--   either <tt>(Text, Value)</tt> or <a>Series</a>. You can use Series
--   when encoding directly to a bytestring builder as in the following
--   example:
--   
--   <pre>
--   toEncoding (Person name age) = pairs ("name" .= name &lt;&gt; "age" .= age)
--   </pre>
data () => Series

-- | Often used synonym for <a>Encoding'</a>.
type Encoding = Encoding' Value

-- | Lifting of the <a>FromJSON</a> class to binary type constructors.
--   
--   Instead of manually writing your <a>FromJSON2</a> instance,
--   <a>Data.Aeson.TH</a> provides Template Haskell functions which will
--   derive an instance at compile time.
class () => FromJSON2 (f :: Type -> Type -> Type)
liftParseJSON2 :: FromJSON2 f => Maybe a -> (Value -> Parser a) -> (Value -> Parser [a]) -> Maybe b -> (Value -> Parser b) -> (Value -> Parser [b]) -> Value -> Parser (f a b)
liftParseJSONList2 :: FromJSON2 f => Maybe a -> (Value -> Parser a) -> (Value -> Parser [a]) -> Maybe b -> (Value -> Parser b) -> (Value -> Parser [b]) -> Value -> Parser [f a b]
liftOmittedField2 :: FromJSON2 f => Maybe a -> Maybe b -> Maybe (f a b)
class (ConstructorNames f, SumFromString f) => GFromJSONKey (f :: Type -> Type)

-- | This type is related to <tt>ToJSONKeyFunction</tt>. If
--   <a>FromJSONKeyValue</a> is used in the <a>FromJSONKey</a> instance,
--   then <tt>ToJSONKeyValue</tt> should be used in the <tt>ToJSONKey</tt>
--   instance. The other three data constructors for this type all
--   correspond to <tt>ToJSONKeyText</tt>. Strictly speaking,
--   <a>FromJSONKeyTextParser</a> is more powerful than
--   <a>FromJSONKeyText</a>, which is in turn more powerful than
--   <a>FromJSONKeyCoerce</a>. For performance reasons, these exist as
--   three options instead of one.
data () => FromJSONKeyFunction a
[FromJSONKeyCoerce] :: forall a. Coercible Text a => FromJSONKeyFunction a
[FromJSONKeyText] :: forall a. !Text -> a -> FromJSONKeyFunction a
[FromJSONKeyTextParser] :: forall a. !Text -> Parser a -> FromJSONKeyFunction a
[FromJSONKeyValue] :: forall a. !Value -> Parser a -> FromJSONKeyFunction a

-- | Read the docs for <tt>ToJSONKey</tt> first. This class is a conversion
--   in the opposite direction. If you have a newtype wrapper around
--   <a>Text</a>, the recommended way to define instances is with
--   generalized newtype deriving:
--   
--   <pre>
--   newtype SomeId = SomeId { getSomeId :: Text }
--     deriving (Eq,Ord,Hashable,FromJSONKey)
--   </pre>
--   
--   If you have a sum of nullary constructors, you may use the generic
--   implementation:
--   
--   <pre>
--   data Color = Red | Green | Blue
--     deriving Generic
--   
--   instance <a>FromJSONKey</a> Color where
--     <a>fromJSONKey</a> = <a>genericFromJSONKey</a> <a>defaultJSONKeyOptions</a>
--   </pre>
class () => FromJSONKey a

-- | Strategy for parsing the key of a map-like container.
fromJSONKey :: FromJSONKey a => FromJSONKeyFunction a

-- | This is similar in spirit to the <a>readList</a> method of
--   <a>Read</a>. It makes it possible to give <a>Value</a> keys special
--   treatment without using <tt>OverlappingInstances</tt>. End users
--   should always be able to use the default implementation of this
--   method.
fromJSONKeyList :: FromJSONKey a => FromJSONKeyFunction [a]

-- | A <a>FromArgs</a> value either stores nothing (for <a>FromJSON</a>) or
--   it stores the three function arguments that decode occurrences of the
--   type parameter (for <a>FromJSON1</a>).
data () => FromArgs arity a

-- | Class of generic representation types that can be converted from JSON.
class () => GFromJSON arity (f :: Type -> Type)

-- | Lifting of the <a>ToJSON</a> class to binary type constructors.
--   
--   Instead of manually writing your <a>ToJSON2</a> instance,
--   <a>Data.Aeson.TH</a> provides Template Haskell functions which will
--   derive an instance at compile time.
--   
--   The compiler cannot provide a default generic implementation for
--   <a>liftToJSON2</a>, unlike <a>toJSON</a> and <a>liftToJSON</a>.
class () => ToJSON2 (f :: Type -> Type -> Type)
liftToJSON2 :: ToJSON2 f => (a -> Bool) -> (a -> Value) -> ([a] -> Value) -> (b -> Bool) -> (b -> Value) -> ([b] -> Value) -> f a b -> Value
liftToJSONList2 :: ToJSON2 f => (a -> Bool) -> (a -> Value) -> ([a] -> Value) -> (b -> Bool) -> (b -> Value) -> ([b] -> Value) -> [f a b] -> Value
liftToEncoding2 :: ToJSON2 f => (a -> Bool) -> (a -> Encoding) -> ([a] -> Encoding) -> (b -> Bool) -> (b -> Encoding) -> ([b] -> Encoding) -> f a b -> Encoding
liftToEncodingList2 :: ToJSON2 f => (a -> Bool) -> (a -> Encoding) -> ([a] -> Encoding) -> (b -> Bool) -> (b -> Encoding) -> ([b] -> Encoding) -> [f a b] -> Encoding

liftOmitField2 :: ToJSON2 f => (a -> Bool) -> (b -> Bool) -> f a b -> Bool

-- | Lifting of the <a>ToJSON</a> class to unary type constructors.
--   
--   Instead of manually writing your <a>ToJSON1</a> instance, there are
--   two options to do it automatically:
--   
--   <ul>
--   <li><a>Data.Aeson.TH</a> provides Template Haskell functions which
--   will derive an instance at compile time. The generated instance is
--   optimized for your type so it will probably be more efficient than the
--   following option.</li>
--   <li>The compiler can provide a default generic implementation for
--   <a>toJSON1</a>.</li>
--   </ul>
--   
--   To use the second, simply add a <tt>deriving <a>Generic1</a></tt>
--   clause to your datatype and declare a <a>ToJSON1</a> instance for your
--   datatype without giving definitions for <a>liftToJSON</a> or
--   <a>liftToEncoding</a>.
--   
--   For example:
--   
--   <pre>
--   {-# LANGUAGE DeriveGeneric #-}
--   
--   import <a>GHC.Generics</a>
--   
--   data Pair a b = Pair { pairFst :: a, pairSnd :: b } deriving <a>Generic1</a>
--   
--   instance <a>ToJSON</a> a =&gt; <a>ToJSON1</a> (Pair a)
--   </pre>
--   
--   If the default implementation doesn't give exactly the results you
--   want, you can customize the generic encoding with only a tiny amount
--   of effort, using <a>genericLiftToJSON</a> and
--   <a>genericLiftToEncoding</a> with your preferred <a>Options</a>:
--   
--   <pre>
--   customOptions = <a>defaultOptions</a>
--                   { <a>fieldLabelModifier</a> = <a>map</a> <a>toUpper</a>
--                   }
--   
--   instance <a>ToJSON</a> a =&gt; <a>ToJSON1</a> (Pair a) where
--       <a>liftToJSON</a>     = <a>genericLiftToJSON</a> customOptions
--       <a>liftToEncoding</a> = <a>genericLiftToEncoding</a> customOptions
--   </pre>
--   
--   See also <a>ToJSON</a>.
class () => ToJSON1 (f :: Type -> Type)
liftToJSON :: ToJSON1 f => (a -> Bool) -> (a -> Value) -> ([a] -> Value) -> f a -> Value
liftToJSONList :: ToJSON1 f => (a -> Bool) -> (a -> Value) -> ([a] -> Value) -> [f a] -> Value
liftToEncoding :: ToJSON1 f => (a -> Bool) -> (a -> Encoding) -> ([a] -> Encoding) -> f a -> Encoding
liftToEncodingList :: ToJSON1 f => (a -> Bool) -> (a -> Encoding) -> ([a] -> Encoding) -> [f a] -> Encoding

liftOmitField :: ToJSON1 f => (a -> Bool) -> f a -> Bool
class GetConName f => GToJSONKey (f :: k -> Type)
data () => ToJSONKeyFunction a

-- | key is encoded to string, produces object
ToJSONKeyText :: !a -> Key -> !a -> Encoding' Key -> ToJSONKeyFunction a

-- | key is encoded to value, produces array
ToJSONKeyValue :: !a -> Value -> !a -> Encoding -> ToJSONKeyFunction a

-- | Typeclass for types that can be used as the key of a map-like
--   container (like <tt>Map</tt> or <tt>HashMap</tt>). For example, since
--   <a>Text</a> has a <a>ToJSONKey</a> instance and <a>Char</a> has a
--   <a>ToJSON</a> instance, we can encode a value of type <tt>Map</tt>
--   <a>Text</a> <a>Char</a>:
--   
--   <pre>
--   &gt;&gt;&gt; LBC8.putStrLn $ encode $ Map.fromList [("foo" :: Text, 'a')]
--   {"foo":"a"}
--   </pre>
--   
--   Since <a>Int</a> also has a <a>ToJSONKey</a> instance, we can
--   similarly write:
--   
--   <pre>
--   &gt;&gt;&gt; LBC8.putStrLn $ encode $ Map.fromList [(5 :: Int, 'a')]
--   {"5":"a"}
--   </pre>
--   
--   JSON documents only accept strings as object keys. For any type from
--   <tt>base</tt> that has a natural textual representation, it can be
--   expected that its <a>ToJSONKey</a> instance will choose that
--   representation.
--   
--   For data types that lack a natural textual representation, an
--   alternative is provided. The map-like container is represented as a
--   JSON array instead of a JSON object. Each value in the array is an
--   array with exactly two values. The first is the key and the second is
--   the value.
--   
--   For example, values of type '[Text]' cannot be encoded to a string, so
--   a <tt>Map</tt> with keys of type '[Text]' is encoded as follows:
--   
--   <pre>
--   &gt;&gt;&gt; LBC8.putStrLn $ encode $ Map.fromList [(["foo","bar","baz" :: Text], 'a')]
--   [[["foo","bar","baz"],"a"]]
--   </pre>
--   
--   The default implementation of <a>ToJSONKey</a> chooses this method of
--   encoding a key, using the <a>ToJSON</a> instance of the type.
--   
--   To use your own data type as the key in a map, all that is needed is
--   to write a <a>ToJSONKey</a> (and possibly a <tt>FromJSONKey</tt>)
--   instance for it. If the type cannot be trivially converted to and from
--   <a>Text</a>, it is recommended that <a>ToJSONKeyValue</a> is used.
--   Since the default implementations of the typeclass methods can build
--   this from a <a>ToJSON</a> instance, there is nothing that needs to be
--   written:
--   
--   <pre>
--   data Foo = Foo { fooAge :: Int, fooName :: Text }
--     deriving (Eq,Ord,Generic)
--   instance ToJSON Foo
--   instance ToJSONKey Foo
--   </pre>
--   
--   That's it. We can now write:
--   
--   <pre>
--   &gt;&gt;&gt; let m = Map.fromList [(Foo 4 "bar",'a'),(Foo 6 "arg",'b')]
--   
--   &gt;&gt;&gt; LBC8.putStrLn $ encode m
--   [[{"fooName":"bar","fooAge":4},"a"],[{"fooName":"arg","fooAge":6},"b"]]
--   </pre>
--   
--   The next case to consider is if we have a type that is a newtype
--   wrapper around <a>Text</a>. The recommended approach is to use
--   generalized newtype deriving:
--   
--   <pre>
--   newtype RecordId = RecordId { getRecordId :: Text }
--     deriving (Eq,Ord,ToJSONKey)
--   </pre>
--   
--   Then we may write:
--   
--   <pre>
--   &gt;&gt;&gt; LBC8.putStrLn $ encode $ Map.fromList [(RecordId "abc",'a')]
--   {"abc":"a"}
--   </pre>
--   
--   Simple sum types are a final case worth considering. Suppose we have:
--   
--   <pre>
--   data Color = Red | Green | Blue
--     deriving (Show,Read,Eq,Ord)
--   </pre>
--   
--   It is possible to get the <a>ToJSONKey</a> instance for free as we did
--   with <tt>Foo</tt>. However, in this case, we have a natural way to go
--   to and from <a>Text</a> that does not require any escape sequences. So
--   <a>ToJSONKeyText</a> can be used instead of <a>ToJSONKeyValue</a> to
--   encode maps as objects instead of arrays of pairs. This instance may
--   be implemented using generics as follows:
--   
--   <pre>
--   instance <a>ToJSONKey</a> Color where
--     <a>toJSONKey</a> = <a>genericToJSONKey</a> <a>defaultJSONKeyOptions</a>
--   </pre>
--   
--   <h3><b>Low-level implementations</b></h3>
--   
--   The <a>Show</a> instance can be used to help write <a>ToJSONKey</a>:
--   
--   <pre>
--   instance ToJSONKey Color where
--     toJSONKey = ToJSONKeyText f g
--       where f = Text.pack . show
--             g = text . Text.pack . show
--             -- text function is from Data.Aeson.Encoding
--   </pre>
--   
--   The situation of needing to turning function <tt>a -&gt; Text</tt>
--   into a <a>ToJSONKeyFunction</a> is common enough that a special
--   combinator is provided for it. The above instance can be rewritten as:
--   
--   <pre>
--   instance ToJSONKey Color where
--     toJSONKey = toJSONKeyText (Text.pack . show)
--   </pre>
--   
--   The performance of the above instance can be improved by not using
--   <a>Value</a> as an intermediate step when converting to <a>Text</a>.
--   One option for improving performance would be to use template haskell
--   machinery from the <tt>text-show</tt> package. However, even with the
--   approach, the <a>Encoding</a> (a wrapper around a bytestring builder)
--   is generated by encoding the <a>Text</a> to a <tt>ByteString</tt>, an
--   intermediate step that could be avoided. The fastest possible
--   implementation would be:
--   
--   <pre>
--   -- Assuming that OverloadedStrings is enabled
--   instance ToJSONKey Color where
--     toJSONKey = ToJSONKeyText f g
--       where f x = case x of {Red -&gt; "Red";Green -&gt;"Green";Blue -&gt; "Blue"}
--             g x = case x of {Red -&gt; text "Red";Green -&gt; text "Green";Blue -&gt; text "Blue"}
--             -- text function is from Data.Aeson.Encoding
--   </pre>
--   
--   This works because GHC can lift the encoded values out of the case
--   statements, which means that they are only evaluated once. This
--   approach should only be used when there is a serious need to maximize
--   performance.
class () => ToJSONKey a

-- | Strategy for rendering the key for a map-like container.
toJSONKey :: ToJSONKey a => ToJSONKeyFunction a

-- | This is similar in spirit to the <tt>showsList</tt> method of
--   <a>Show</a>. It makes it possible to give <a>Value</a> keys special
--   treatment without using <tt>OverlappingInstances</tt>. End users
--   should always be able to use the default implementation of this
--   method.
toJSONKeyList :: ToJSONKey a => ToJSONKeyFunction [a]

-- | An optional key-value pair for envoding to a JSON object
class KeyValue e kv => KeyValueOmit e kv | kv -> e
(.?=) :: (KeyValueOmit e kv, ToJSON v) => Key -> v -> kv
explicitToFieldOmit :: KeyValueOmit e kv => (v -> Bool) -> (v -> e) -> Key -> v -> kv
infixr 8 .?=

-- | A key-value pair for encoding a JSON object.
class () => KeyValue e kv | kv -> e

explicitToField :: KeyValue e kv => (v -> e) -> Key -> v -> kv

-- | A type that can be converted to JSON.
--   
--   Instances in general <i>must</i> specify <a>toJSON</a> and
--   <i>should</i> (but don't need to) specify <a>toEncoding</a>.
--   
--   An example type and instance:
--   
--   <pre>
--   -- Allow ourselves to write <a>Text</a> literals.
--   {-# LANGUAGE OverloadedStrings #-}
--   
--   data Coord = Coord { x :: Double, y :: Double }
--   
--   instance <a>ToJSON</a> Coord where
--     <a>toJSON</a> (Coord x y) = <a>object</a> ["x" <a>.=</a> x, "y" <a>.=</a> y]
--   
--     <a>toEncoding</a> (Coord x y) = <tt>pairs</tt> ("x" <a>.=</a> x <a>&lt;&gt;</a> "y" <a>.=</a> y)
--   </pre>
--   
--   Instead of manually writing your <a>ToJSON</a> instance, there are two
--   options to do it automatically:
--   
--   <ul>
--   <li><a>Data.Aeson.TH</a> provides Template Haskell functions which
--   will derive an instance at compile time. The generated instance is
--   optimized for your type so it will probably be more efficient than the
--   following option.</li>
--   <li>The compiler can provide a default generic implementation for
--   <a>toJSON</a>.</li>
--   </ul>
--   
--   To use the second, simply add a <tt>deriving <a>Generic</a></tt>
--   clause to your datatype and declare a <a>ToJSON</a> instance. If you
--   require nothing other than <a>defaultOptions</a>, it is sufficient to
--   write (and this is the only alternative where the default
--   <a>toJSON</a> implementation is sufficient):
--   
--   <pre>
--   {-# LANGUAGE DeriveGeneric #-}
--   
--   import <a>GHC.Generics</a>
--   
--   data Coord = Coord { x :: Double, y :: Double } deriving <a>Generic</a>
--   
--   instance <a>ToJSON</a> Coord where
--       <a>toEncoding</a> = <a>genericToEncoding</a> <a>defaultOptions</a>
--   </pre>
--   
--   or more conveniently using the <a>DerivingVia extension</a>
--   
--   <pre>
--   deriving via <a>Generically</a> Coord instance <a>ToJSON</a> Coord
--   </pre>
--   
--   If on the other hand you wish to customize the generic decoding, you
--   have to implement both methods:
--   
--   <pre>
--   customOptions = <a>defaultOptions</a>
--                   { <a>fieldLabelModifier</a> = <a>map</a> <a>toUpper</a>
--                   }
--   
--   instance <a>ToJSON</a> Coord where
--       <a>toJSON</a>     = <a>genericToJSON</a> customOptions
--       <a>toEncoding</a> = <a>genericToEncoding</a> customOptions
--   </pre>
--   
--   Previous versions of this library only had the <a>toJSON</a> method.
--   Adding <a>toEncoding</a> had two reasons:
--   
--   <ol>
--   <li><a>toEncoding</a> is more efficient for the common case that the
--   output of <a>toJSON</a> is directly serialized to a
--   <tt>ByteString</tt>. Further, expressing either method in terms of the
--   other would be non-optimal.</li>
--   <li>The choice of defaults allows a smooth transition for existing
--   users: Existing instances that do not define <a>toEncoding</a> still
--   compile and have the correct semantics. This is ensured by making the
--   default implementation of <a>toEncoding</a> use <a>toJSON</a>. This
--   produces correct results, but since it performs an intermediate
--   conversion to a <a>Value</a>, it will be less efficient than directly
--   emitting an <a>Encoding</a>. (this also means that specifying nothing
--   more than <tt>instance ToJSON Coord</tt> would be sufficient as a
--   generically decoding instance, but there probably exists no good
--   reason to not specify <a>toEncoding</a> in new instances.)</li>
--   </ol>
class () => ToJSON a

-- | Convert a Haskell value to a JSON-friendly intermediate type.
toJSON :: ToJSON a => a -> Value

-- | Encode a Haskell value as JSON.
--   
--   The default implementation of this method creates an intermediate
--   <a>Value</a> using <a>toJSON</a>. This provides source-level
--   compatibility for people upgrading from older versions of this
--   library, but obviously offers no performance advantage.
--   
--   To benefit from direct encoding, you <i>must</i> provide an
--   implementation for this method. The easiest way to do so is by having
--   your types implement <a>Generic</a> using the <tt>DeriveGeneric</tt>
--   extension, and then have GHC generate a method body as follows.
--   
--   <pre>
--   instance <a>ToJSON</a> Coord where
--       <a>toEncoding</a> = <a>genericToEncoding</a> <a>defaultOptions</a>
--   </pre>
toEncoding :: ToJSON a => a -> Encoding
toJSONList :: ToJSON a => [a] -> Value
toEncodingList :: ToJSON a => [a] -> Encoding

-- | Defines when it is acceptable to omit a field of this type from a
--   record. Used by <tt>(<a>.?=</a>)</tt> operator, and Generics and TH
--   deriving with <tt><a>omitNothingFields</a> = True</tt>.
omitField :: ToJSON a => a -> Bool

-- | A <a>ToArgs</a> value either stores nothing (for <a>ToJSON</a>) or it
--   stores the three function arguments that encode occurrences of the
--   type parameter (for <a>ToJSON1</a>).
data () => ToArgs res arity a

-- | Class of generic representation types that can be converted to JSON.
class () => GToJSON' enc arity (f :: Type -> Type)
type GToEncoding = GToJSON' Encoding
type GToJSON = GToJSON' Value

-- | <a>fromJSONKey</a> for <a>Generic</a> types. These types must be sums
--   of nullary constructors, whose names will be used as keys for JSON
--   objects.
--   
--   See also <tt>genericToJSONKey</tt>.
--   
--   <h3><b>Example</b></h3>
--   
--   <pre>
--   data Color = Red | Green | Blue
--     deriving <a>Generic</a>
--   
--   instance <a>FromJSONKey</a> Color where
--     <a>fromJSONKey</a> = <a>genericFromJSONKey</a> <a>defaultJSONKeyOptions</a>
--   </pre>
genericFromJSONKey :: (Generic a, GFromJSONKey (Rep a)) => JSONKeyOptions -> FromJSONKeyFunction a
genericToJSONKey :: (Generic a, GToJSONKey (Rep a)) => JSONKeyOptions -> ToJSONKeyFunction a

-- | Create a <a>Value</a> from a list of name/value <a>Pair</a>s. If
--   duplicate keys arise, later keys and their associated values win.
object :: [Pair] -> Value

-- | Add JSON Path context to a parser
--   
--   When parsing a complex structure, it helps to annotate (sub)parsers
--   with context, so that if an error occurs, you can find its location.
--   
--   <pre>
--   withObject "Person" $ \o -&gt;
--     Person
--       &lt;$&gt; o .: "name" &lt;?&gt; Key "name"
--       &lt;*&gt; o .: "age"  &lt;?&gt; Key "age"
--   </pre>
--   
--   (Standard methods like <tt>(.:)</tt> already do this.)
--   
--   With such annotations, if an error occurs, you will get a JSON Path
--   location of that error.
--   
--   Since 0.10
(<?>) :: Parser a -> JSONPathElement -> Parser a

-- | Default encoding <a>Options</a>:
--   
--   <pre>
--   <a>Options</a>
--   { <a>fieldLabelModifier</a>      = id
--   , <a>constructorTagModifier</a>  = id
--   , <a>allNullaryToStringTag</a>   = True
--   , <a>omitNothingFields</a>       = False
--   , <a>allowOmittedFields</a>      = True
--   , <a>sumEncoding</a>             = <a>defaultTaggedObject</a>
--   , <a>unwrapUnaryRecords</a>      = False
--   , <a>tagSingleConstructors</a>   = False
--   , <a>rejectUnknownFields</a>     = False
--   }
--   </pre>
defaultOptions :: Options

-- | Default <a>TaggedObject</a> <a>SumEncoding</a> options:
--   
--   <pre>
--   defaultTaggedObject = <a>TaggedObject</a>
--                         { <a>tagFieldName</a>      = "tag"
--                         , <a>contentsFieldName</a> = "contents"
--                         }
--   </pre>
defaultTaggedObject :: SumEncoding

-- | Default <a>JSONKeyOptions</a>:
--   
--   <pre>
--   defaultJSONKeyOptions = <a>JSONKeyOptions</a>
--                           { <a>keyModifier</a> = <a>id</a>
--                           }
--   </pre>
defaultJSONKeyOptions :: JSONKeyOptions

-- | Better version of <a>camelTo</a>. Example where it works better:
--   
--   <pre>
--   camelTo '_' "CamelAPICase" == "camel_apicase"
--   camelTo2 '_' "CamelAPICase" == "camel_api_case"
--   </pre>
camelTo2 :: Char -> String -> String

-- | Acquire the underlying bytestring builder.
fromEncoding :: Encoding' tag -> Builder

-- | Encode a series of key/value pairs, separated by commas.
pairs :: Series -> Encoding
parseIndexedJSON :: (Value -> Parser a) -> Int -> Value -> Parser a

-- | A configurable generic JSON decoder. This function applied to
--   <a>defaultOptions</a> is used as the default for <a>parseJSON</a> when
--   the type is an instance of <a>Generic</a>.
genericParseJSON :: (Generic a, GFromJSON Zero (Rep a)) => Options -> Value -> Parser a

-- | A configurable generic JSON decoder. This function applied to
--   <a>defaultOptions</a> is used as the default for <a>liftParseJSON</a>
--   when the type is an instance of <a>Generic1</a>.
genericLiftParseJSON :: (Generic1 f, GFromJSON One (Rep1 f)) => Options -> Maybe a -> (Value -> Parser a) -> (Value -> Parser [a]) -> Value -> Parser (f a)

-- | Lift the standard <a>parseJSON</a> function through the type
--   constructor.
parseJSON1 :: (FromJSON1 f, FromJSON a) => Value -> Parser (f a)

omittedField1 :: (FromJSON1 f, FromJSON a) => Maybe (f a)

-- | Lift the standard <a>parseJSON</a> function through the type
--   constructor.
parseJSON2 :: (FromJSON2 f, FromJSON a, FromJSON b) => Value -> Parser (f a b)

omittedField2 :: (FromJSON2 f, FromJSON a, FromJSON b) => Maybe (f a b)

-- | <tt><a>withObject</a> name f value</tt> applies <tt>f</tt> to the
--   <a>Object</a> when <tt>value</tt> is an <a>Object</a> and fails
--   otherwise.
--   
--   <h4>Error message example</h4>
--   
--   <pre>
--   withObject "MyType" f (String "oops")
--   -- Error: "parsing MyType failed, expected Object, but encountered String"
--   </pre>
withObject :: String -> (Object -> Parser a) -> Value -> Parser a

-- | <tt><a>withText</a> name f value</tt> applies <tt>f</tt> to the
--   <a>Text</a> when <tt>value</tt> is a <a>String</a> and fails
--   otherwise.
--   
--   <h4>Error message example</h4>
--   
--   <pre>
--   withText "MyType" f Null
--   -- Error: "parsing MyType failed, expected String, but encountered Null"
--   </pre>
withText :: String -> (Text -> Parser a) -> Value -> Parser a

-- | <tt><a>withArray</a> expected f value</tt> applies <tt>f</tt> to the
--   <a>Array</a> when <tt>value</tt> is an <a>Array</a> and fails
--   otherwise.
--   
--   <h4>Error message example</h4>
--   
--   <pre>
--   withArray "MyType" f (String "oops")
--   -- Error: "parsing MyType failed, expected Array, but encountered String"
--   </pre>
withArray :: String -> (Array -> Parser a) -> Value -> Parser a

-- | <tt><a>withScientific</a> name f value</tt> applies <tt>f</tt> to the
--   <a>Scientific</a> number when <tt>value</tt> is a <a>Number</a> and
--   fails using <a>typeMismatch</a> otherwise.
--   
--   <i>Warning</i>: If you are converting from a scientific to an
--   unbounded type such as <a>Integer</a> you may want to add a
--   restriction on the size of the exponent (see
--   <a>withBoundedScientific</a>) to prevent malicious input from filling
--   up the memory of the target system.
--   
--   <h4>Error message example</h4>
--   
--   <pre>
--   withScientific "MyType" f (String "oops")
--   -- Error: "parsing MyType failed, expected Number, but encountered String"
--   </pre>
withScientific :: String -> (Scientific -> Parser a) -> Value -> Parser a

-- | <tt><a>withBool</a> expected f value</tt> applies <tt>f</tt> to the
--   <a>Value</a> when <tt>value</tt> is a <tt>Boolean</tt> and fails
--   otherwise.
--   
--   <h4>Error message example</h4>
--   
--   <pre>
--   withBool "MyType" f (String "oops")
--   -- Error: "parsing MyType failed, expected Boolean, but encountered String"
--   </pre>
withBool :: String -> (Bool -> Parser a) -> Value -> Parser a

-- | Decode a nested JSON-encoded string.
withEmbeddedJSON :: String -> (Value -> Parser a) -> Value -> Parser a

-- | Convert a value from JSON, failing if the types do not match.
fromJSON :: FromJSON a => Value -> Result a

-- | Retrieve the value associated with the given key of an <a>Object</a>.
--   The result is <a>empty</a> if the key is not present or the value
--   cannot be converted to the desired type.
--   
--   This accessor is appropriate if the key and value <i>must</i> be
--   present in an object for it to be valid. If the key and value are
--   optional, use <a>.:?</a> instead.
(.:) :: FromJSON a => Object -> Key -> Parser a

-- | Retrieve the value associated with the given key of an <a>Object</a>.
--   The result is <a>Nothing</a> if the key is not present or if its value
--   is <a>Null</a>, or <a>empty</a> if the value cannot be converted to
--   the desired type.
--   
--   This accessor is most useful if the key and value can be absent from
--   an object without affecting its validity. If the key and value are
--   mandatory, use <a>.:</a> instead.
(.:?) :: FromJSON a => Object -> Key -> Parser (Maybe a)

-- | Retrieve the value associated with the given key of an <a>Object</a>.
--   The result is <a>Nothing</a> if the key is not present or <a>empty</a>
--   if the value cannot be converted to the desired type.
--   
--   This differs from <a>.:?</a> by attempting to parse <a>Null</a> the
--   same as any other JSON value, instead of interpreting it as
--   <a>Nothing</a>.
(.:!) :: FromJSON a => Object -> Key -> Parser (Maybe a)

-- | Retrieve the value associated with the given key of an <a>Object</a>.
--   If the key is not present or the field is <tt>null</tt> and the
--   <a>omittedField</a> is <tt><a>Just</a> x</tt> for some <tt>x</tt>, the
--   result will be that <tt>x</tt>.
(.:?=) :: FromJSON a => Object -> Key -> Parser a

-- | Retrieve the value associated with the given key of an <a>Object</a>.
--   If the key is not present and the <a>omittedField</a> is
--   <tt><a>Just</a> x</tt> for some <tt>x</tt>, the result will be that
--   <tt>x</tt>.
--   
--   This differs from <a>.:?=</a> by attempting to parse <a>Null</a> the
--   same as any other JSON value, instead of using <a>omittedField</a>
--   when it's <a>Just</a>.
(.:!=) :: FromJSON a => Object -> Key -> Parser a

-- | Helper for use in combination with <a>.:?</a> to provide default
--   values for optional JSON object fields.
--   
--   This combinator is most useful if the key and value can be absent from
--   an object without affecting its validity and we know a default value
--   to assign in that case. If the key and value are mandatory, use
--   <a>.:</a> instead.
--   
--   Example usage:
--   
--   <pre>
--   v1 &lt;- o <a>.:?</a> "opt_field_with_dfl" .!= "default_val"
--   v2 &lt;- o <a>.:</a>  "mandatory_field"
--   v3 &lt;- o <a>.:?</a> "opt_field2"
--   </pre>
(.!=) :: Parser (Maybe a) -> a -> Parser a

-- | A configurable generic JSON creator. This function applied to
--   <a>defaultOptions</a> is used as the default for <a>toJSON</a> when
--   the type is an instance of <a>Generic</a>.
genericToJSON :: (Generic a, GToJSON' Value Zero (Rep a)) => Options -> a -> Value

-- | A configurable generic JSON creator. This function applied to
--   <a>defaultOptions</a> is used as the default for <a>liftToJSON</a>
--   when the type is an instance of <a>Generic1</a>.
genericLiftToJSON :: (Generic1 f, GToJSON' Value One (Rep1 f)) => Options -> (a -> Bool) -> (a -> Value) -> ([a] -> Value) -> f a -> Value

-- | A configurable generic JSON encoder. This function applied to
--   <a>defaultOptions</a> is used as the default for <a>toEncoding</a>
--   when the type is an instance of <a>Generic</a>.
genericToEncoding :: (Generic a, GToJSON' Encoding Zero (Rep a)) => Options -> a -> Encoding

-- | A configurable generic JSON encoder. This function applied to
--   <a>defaultOptions</a> is used as the default for <a>liftToEncoding</a>
--   when the type is an instance of <a>Generic1</a>.
genericLiftToEncoding :: (Generic1 f, GToJSON' Encoding One (Rep1 f)) => Options -> (a -> Bool) -> (a -> Encoding) -> ([a] -> Encoding) -> f a -> Encoding

-- | Lift the standard <a>toJSON</a> function through the type constructor.
toJSON1 :: (ToJSON1 f, ToJSON a) => f a -> Value

-- | Lift the standard <a>toEncoding</a> function through the type
--   constructor.
toEncoding1 :: (ToJSON1 f, ToJSON a) => f a -> Encoding
omitField1 :: (ToJSON1 f, ToJSON a) => f a -> Bool

-- | Lift the standard <a>toJSON</a> function through the type constructor.
toJSON2 :: (ToJSON2 f, ToJSON a, ToJSON b) => f a b -> Value

-- | Lift the standard <a>toEncoding</a> function through the type
--   constructor.
toEncoding2 :: (ToJSON2 f, ToJSON a, ToJSON b) => f a b -> Encoding
omitField2 :: (ToJSON2 f, ToJSON a, ToJSON b) => f a b -> Bool

-- | Encode a <a>Foldable</a> as a JSON array.
foldable :: (Foldable t, ToJSON a) => t a -> Encoding

-- | Efficiently deserialize a JSON value from a strict <a>ByteString</a>.
--   If this fails due to incomplete or invalid input, <a>Nothing</a> is
--   returned.
decodeStrict :: FromJSON a => ByteString -> Maybe a

-- | Like <a>decodeStrict</a> but returns an error message when decoding
--   fails.
eitherDecodeStrict :: FromJSON a => ByteString -> Either String a

-- | Like <a>decodeStrict</a> but throws an <a>AesonException</a> when
--   decoding fails.
throwDecodeStrict :: (FromJSON a, MonadThrow m) => ByteString -> m a

-- | Efficiently deserialize a JSON value from a lazy <a>ByteString</a>. If
--   this fails due to incomplete or invalid input, <a>Nothing</a> is
--   returned.
decode :: FromJSON a => ByteString -> Maybe a

-- | Like <a>decode</a> but returns an error message when decoding fails.
eitherDecode :: FromJSON a => ByteString -> Either String a

-- | Like <a>decode</a> but throws an <a>AesonException</a> when decoding
--   fails.
--   
--   <a>throwDecode</a> is in <tt>aeson</tt> since 2.1.2.0, but this
--   variant is added later.
throwDecode :: (FromJSON a, MonadThrow m) => ByteString -> m a

-- | Efficiently deserialize a JSON value from a strict <a>Text</a>. If
--   this fails due to incomplete or invalid input, <a>Nothing</a> is
--   returned.
decodeStrictText :: FromJSON a => Text -> Maybe a

-- | Like <a>decodeStrictText</a> but returns an error message when
--   decoding fails.
eitherDecodeStrictText :: FromJSON a => Text -> Either String a

-- | Like <a>decodeStrictText</a> but throws an <a>AesonException</a> when
--   decoding fails.
throwDecodeStrictText :: (FromJSON a, MonadThrow m) => Text -> m a

-- | Efficiently serialize a JSON value as a lazy <a>ByteString</a>.
--   
--   This is implemented in terms of the <a>ToJSON</a> class's
--   <a>toEncoding</a> method.
encode :: ToJSON a => a -> ByteString

-- | Efficiently serialize a JSON value as a lazy <a>ByteString</a> and
--   write it to a file.
encodeFile :: ToJSON a => FilePath -> a -> IO ()

-- | Efficiently deserialize a JSON value from a file. If this fails due to
--   incomplete or invalid input, <a>Nothing</a> is returned.
--   
--   The input file's content must consist solely of a JSON document, with
--   no trailing data except for whitespace.
--   
--   This function parses immediately, but defers conversion. See
--   <tt>json</tt> for details.
decodeFileStrict :: FromJSON a => FilePath -> IO (Maybe a)

-- | Efficiently deserialize a JSON value from a lazy <a>ByteString</a>. If
--   this fails due to incomplete or invalid input, <a>Nothing</a> is
--   returned.
--   
--   Since <tt>2.2.0.0</tt> an alias for <a>decode</a>.
decode' :: FromJSON a => ByteString -> Maybe a

-- | Efficiently deserialize a JSON value from a strict <a>ByteString</a>.
--   If this fails due to incomplete or invalid input, <a>Nothing</a> is
--   returned.
--   
--   Since <tt>2.2.0.0</tt> an alias for <a>decodeStrict</a>.
decodeStrict' :: FromJSON a => ByteString -> Maybe a

-- | Efficiently deserialize a JSON value from a file. If this fails due to
--   incomplete or invalid input, <a>Nothing</a> is returned.
--   
--   Since <tt>2.2.0.0</tt> an alias for <a>decodeFileStrict</a>.
decodeFileStrict' :: FromJSON a => FilePath -> IO (Maybe a)

-- | Like <a>decodeFileStrict</a> but returns an error message when
--   decoding fails.
eitherDecodeFileStrict :: FromJSON a => FilePath -> IO (Either String a)

-- | Like <a>decode'</a> but returns an error message when decoding fails.
--   
--   Since <tt>2.2.0.0</tt> an alias for <a>eitherDecode</a>.
eitherDecode' :: FromJSON a => ByteString -> Either String a

-- | Like <a>decodeStrict'</a> but returns an error message when decoding
--   fails.
--   
--   Since <tt>2.2.0.0</tt> an alias for <a>eitherDecodeStrict</a>.
eitherDecodeStrict' :: FromJSON a => ByteString -> Either String a

-- | Like <a>decodeFileStrict'</a> but returns an error message when
--   decoding fails.
--   
--   Since <tt>2.2.0.0</tt> an alias for <a>eitherDecodeFileStrict'</a>.
eitherDecodeFileStrict' :: FromJSON a => FilePath -> IO (Either String a)

-- | Like <a>decode'</a> but throws an <a>AesonException</a> when decoding
--   fails.
--   
--   Since <tt>2.2.0.0</tt> an alias for <a>throwDecode</a>.
throwDecode' :: (FromJSON a, MonadThrow m) => ByteString -> m a

-- | Like <a>decodeStrict'</a> but throws an <a>AesonException</a> when
--   decoding fails.
--   
--   Since <tt>2.2.0.0</tt> an alias for <a>throwDecodeStrict</a>.
throwDecodeStrict' :: (FromJSON a, MonadThrow m) => ByteString -> m a

-- | Left-to-right composition of Kleisli arrows.
--   
--   '<tt>(bs <a>&gt;=&gt;</a> cs) a</tt>' can be understood as the
--   <tt>do</tt> expression
--   
--   <pre>
--   do b &lt;- bs a
--      cs b
--   </pre>
(>=>) :: Monad m => (a -> m b) -> (b -> m c) -> a -> m c
infixr 1 >=>

-- | Right-to-left composition of Kleisli arrows.
--   <tt>(<a>&gt;=&gt;</a>)</tt>, with the arguments flipped.
--   
--   Note how this operator resembles function composition
--   <tt>(<a>.</a>)</tt>:
--   
--   <pre>
--   (.)   ::            (b -&gt;   c) -&gt; (a -&gt;   b) -&gt; a -&gt;   c
--   (&lt;=&lt;) :: Monad m =&gt; (b -&gt; m c) -&gt; (a -&gt; m b) -&gt; a -&gt; m c
--   </pre>
(<=<) :: Monad m => (b -> m c) -> (a -> m b) -> a -> m c
infixr 1 <=<

-- | The JSON version of<tt>PrettyTCM</tt>, for encoding JSON value in TCM
class EncodeTCM a
encodeTCM :: EncodeTCM a => a -> TCM Value
encodeTCM :: (EncodeTCM a, ToJSON a) => a -> TCM Value

-- | TCM monadic version of object
obj :: [TCM Pair] -> TCM Value

-- | A handy alternative of <a>obj</a> with kind specified
kind :: Text -> [TCM Pair] -> TCM Value

-- | A handy alternative of <a>object</a> with kind specified
kind' :: Text -> [Pair] -> Value

-- | A key-value pair for encoding a JSON object.
(.=) :: ToJSON a => Text -> a -> Pair

-- | Abbreviation of `_ #= encodeTCM _`
(@=) :: EncodeTCM a => Text -> a -> TCM Pair

-- | Pairs a key with a value wrapped in TCM
(#=) :: ToJSON a => Text -> TCM a -> TCM Pair
instance Agda.Interaction.JSON.EncodeTCM a => Agda.Interaction.JSON.EncodeTCM [a]
instance Agda.Interaction.JSON.EncodeTCM GHC.Base.String
instance Agda.Interaction.JSON.EncodeTCM GHC.Types.Bool
instance Agda.Interaction.JSON.EncodeTCM GHC.Types.Int
instance Agda.Interaction.JSON.EncodeTCM GHC.Int.Int32
instance Agda.Interaction.JSON.EncodeTCM Data.Aeson.Types.Internal.Value
instance Agda.Interaction.JSON.EncodeTCM Agda.Syntax.Common.Pretty.Doc
instance Agda.Interaction.JSON.EncodeTCM a => Agda.Interaction.JSON.EncodeTCM (GHC.Maybe.Maybe a)
instance Data.Aeson.Types.ToJSON.ToJSON Agda.Syntax.Common.Pretty.Doc
instance Data.Aeson.Types.ToJSON.ToJSON Agda.Utils.FileName.AbsolutePath

module Agda.Interaction.Highlighting.Vim
vimFile :: FilePath -> FilePath
escape :: String -> String
wordBounded :: String -> String
keyword :: String -> [String] -> String
match :: String -> List1 String -> String
matches :: [String] -> [String] -> [String] -> [String] -> [String] -> [String] -> [String]
toVim :: NamesInScope -> String
generateVimFile :: FilePath -> TCM ()


-- | Extract highlighting syntax from abstract syntax.
--   
--   Implements one big fold over abstract syntax.
module Agda.Interaction.Highlighting.FromAbstract

-- | Create highlighting info for some piece of syntax.
runHighlighter :: Hilite a => TopLevelModuleName -> NameKinds -> a -> HighlightingInfoBuilder

-- | A function mapping names to the kind of name they stand for.
type NameKinds = QName -> Maybe NameKind
instance (Agda.Interaction.Highlighting.FromAbstract.Hilite m, Agda.Interaction.Highlighting.FromAbstract.Hilite n, Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Interaction.Highlighting.FromAbstract.RenamingTo m), Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Interaction.Highlighting.FromAbstract.RenamingTo n)) => Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Syntax.Common.ImportDirective' m n)
instance (Agda.Interaction.Highlighting.FromAbstract.Hilite m, Agda.Interaction.Highlighting.FromAbstract.Hilite n, Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Interaction.Highlighting.FromAbstract.RenamingTo m), Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Interaction.Highlighting.FromAbstract.RenamingTo n)) => Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Syntax.Common.Renaming' m n)
instance Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Interaction.Highlighting.FromAbstract.RenamingTo Agda.Syntax.Abstract.Name.QName)
instance Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Interaction.Highlighting.FromAbstract.RenamingTo Agda.Syntax.Abstract.Name.ModuleName)
instance (Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Interaction.Highlighting.FromAbstract.RenamingTo m), Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Interaction.Highlighting.FromAbstract.RenamingTo n)) => Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Interaction.Highlighting.FromAbstract.RenamingTo (Agda.Syntax.Common.ImportedName' m n))
instance Agda.Interaction.Highlighting.FromAbstract.Hilite a => Agda.Interaction.Highlighting.FromAbstract.Hilite [a]
instance Agda.Interaction.Highlighting.FromAbstract.Hilite a => Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Utils.List1.List1 a)
instance Agda.Interaction.Highlighting.FromAbstract.Hilite a => Agda.Interaction.Highlighting.FromAbstract.Hilite (GHC.Maybe.Maybe a)
instance Agda.Interaction.Highlighting.FromAbstract.Hilite a => Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Syntax.Common.Ranged a)
instance Agda.Interaction.Highlighting.FromAbstract.Hilite a => Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Syntax.Concrete.TacticAttribute' a)
instance Agda.Interaction.Highlighting.FromAbstract.Hilite a => Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Syntax.Common.WithHiding a)
instance Agda.Interaction.Highlighting.FromAbstract.Hilite GHC.Base.Void
instance (Agda.Interaction.Highlighting.FromAbstract.Hilite a, Agda.Interaction.Highlighting.FromAbstract.Hilite b) => Agda.Interaction.Highlighting.FromAbstract.Hilite (Data.Either.Either a b)
instance (Agda.Interaction.Highlighting.FromAbstract.Hilite a, Agda.Interaction.Highlighting.FromAbstract.Hilite b) => Agda.Interaction.Highlighting.FromAbstract.Hilite (a, b)
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.RecordDirectives
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.Declaration
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.Pragma
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.Expr
instance (Agda.Interaction.Highlighting.FromAbstract.Hilite a, Agda.Syntax.Abstract.Name.IsProjP a) => Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Syntax.Abstract.Pattern' a)
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Literal.Literal
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.LHS
instance (Agda.Interaction.Highlighting.FromAbstract.Hilite a, Agda.Syntax.Abstract.Name.IsProjP a) => Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Syntax.Abstract.LHSCore' a)
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.RHS
instance (Agda.Syntax.Position.HasRange n, Agda.Interaction.Highlighting.FromAbstract.Hilite p, Agda.Interaction.Highlighting.FromAbstract.Hilite e) => Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Syntax.Common.RewriteEqn' x n p e)
instance Agda.Interaction.Highlighting.FromAbstract.Hilite a => Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Syntax.Abstract.Clause' a)
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.ProblemEq
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.WhereDeclarations
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.GeneralizeTelescope
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.DataDefParams
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.ModuleApplication
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.LetBinding
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.TypedBindingInfo
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.TypedBinding
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.LamBinding
instance Agda.Interaction.Highlighting.FromAbstract.Hilite a => Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Syntax.Abstract.Binder' a)
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.BindName
instance Agda.Interaction.Highlighting.FromAbstract.Hilite a => Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Syntax.Concrete.FieldAssignment' a)
instance (Agda.Interaction.Highlighting.FromAbstract.Hilite a, Agda.Syntax.Position.HasRange n) => Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Syntax.Common.Named n a)
instance Agda.Interaction.Highlighting.FromAbstract.Hilite a => Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Syntax.Common.Arg a)
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Common.ArgInfo
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Common.Modality
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Common.Quantity
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Common.Erased
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Info.ModuleInfo
instance (Agda.Interaction.Highlighting.FromAbstract.Hilite m, Agda.Interaction.Highlighting.FromAbstract.Hilite n) => Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Syntax.Common.Using' m n)
instance (Agda.Interaction.Highlighting.FromAbstract.Hilite m, Agda.Interaction.Highlighting.FromAbstract.Hilite n) => Agda.Interaction.Highlighting.FromAbstract.Hilite (Agda.Syntax.Common.ImportedName' m n)
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.TypeChecking.Monad.Base.DisambiguatedName
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Scope.Base.ResolvedName
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.Name.QName
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.Name.AmbiguousQName
instance Agda.Interaction.Highlighting.FromAbstract.Hilite Agda.Syntax.Abstract.Name.ModuleName
instance GHC.Base.Monoid Agda.Interaction.Highlighting.FromAbstract.Hiliter


-- | Generates data used for precise syntax highlighting.
module Agda.Interaction.Highlighting.Generate

-- | Highlighting levels.
data Level

-- | Full highlighting. Should only be used after typechecking has
--   completed successfully.
Full :: Level

-- | Highlighting without disambiguation of overloaded constructors.
Partial :: Level

-- | Generate syntax highlighting information for the given declaration,
--   and (if appropriate) print it. If the boolean is <a>True</a>, then the
--   state is additionally updated with the new highlighting info (in case
--   of a conflict new info takes precedence over old info).
--   
--   The procedure makes use of some of the highlighting info corresponding
--   to <a>stTokens</a> (that corresponding to the interval covered by the
--   declaration). If the boolean is <a>True</a>, then this highlighting
--   info is additionally removed from the data structure that
--   <a>stTokens</a> refers to.
generateAndPrintSyntaxInfo :: Declaration -> Level -> Bool -> TCM ()

-- | Generate and return the syntax highlighting information for the tokens
--   in the given file.
generateTokenInfo :: AbsolutePath -> TCM HighlightingInfo

-- | Generate and return the syntax highlighting information for the tokens
--   in the given file.
generateTokenInfoFromSource :: RangeFile -> String -> TCM HighlightingInfo

-- | Generate and return the syntax highlighting information for the tokens
--   in the given string, which is assumed to correspond to the given
--   range.
generateTokenInfoFromString :: Range -> String -> TCM HighlightingInfo
printSyntaxInfo :: Range -> TCM ()

-- | Prints syntax highlighting info for an error.
printErrorInfo :: TCErr -> TCM ()

-- | Generate highlighting for error.
errorHighlighting :: TCErr -> TCM HighlightingInfoBuilder

-- | Generates and prints syntax highlighting information for unsolved
--   meta-variables and certain unsolved constraints.
printUnsolvedInfo :: TCM ()

-- | Lispify and print the given highlighting information.
printHighlightingInfo :: MonadTrace m => RemoveTokenBasedHighlighting -> HighlightingInfo -> m ()

-- | <tt>highlightAsTypeChecked rPre r m</tt> runs <tt>m</tt> and returns
--   its result. Additionally, some code may be highlighted:
--   
--   <ul>
--   <li>If <tt>r</tt> is non-empty and not a sub-range of <tt>rPre</tt>
--   (after <a>continuousPerLine</a> has been applied to both): <tt>r</tt>
--   is highlighted as being type-checked while <tt>m</tt> is running (this
--   highlighting is removed if <tt>m</tt> completes
--   <i>successfully</i>).</li>
--   <li>Otherwise: Highlighting is removed for <tt>rPre - r</tt> before
--   <tt>m</tt> runs, and if <tt>m</tt> completes successfully, then
--   <tt>rPre - r</tt> is highlighted as being type-checked.</li>
--   </ul>
highlightAsTypeChecked :: MonadTrace m => Range -> Range -> m a -> m a

-- | Highlight a warning. We do not generate highlighting for unsolved
--   metas and constraints, as that gets handled in bulk after
--   typechecking.
highlightWarning :: TCWarning -> TCM ()

-- | Generate syntax highlighting for warnings.
warningHighlighting :: TCWarning -> HighlightingInfoBuilder
computeUnsolvedInfo :: TCM HighlightingInfoBuilder
storeDisambiguatedConstructor :: Induction -> QName -> TCM ()
storeDisambiguatedProjection :: QName -> TCM ()

-- | Store a disambiguation of record field tags for the purpose of
--   highlighting.
disambiguateRecordFields :: [Name] -> [QName] -> TCM ()
instance GHC.Base.Semigroup Agda.Interaction.Highlighting.Generate.NameKindBuilder
instance GHC.Base.Monoid Agda.Interaction.Highlighting.Generate.NameKindBuilder
instance Agda.Utils.Singleton.Singleton Agda.Syntax.Abstract.Views.KName Agda.Interaction.Highlighting.Generate.NameKindBuilder
instance Agda.Utils.Singleton.Collection Agda.Syntax.Abstract.Views.KName Agda.Interaction.Highlighting.Generate.NameKindBuilder

module Agda.TypeChecking.Rules.LHS

-- | Check a LHS. Main function.
--   
--   <tt>checkLeftHandSide a ps a ret</tt> checks that user patterns
--   <tt>ps</tt> eliminate the type <tt>a</tt> of the defined function, and
--   calls continuation <tt>ret</tt> if successful.
checkLeftHandSide :: forall a. Call -> Range -> Maybe QName -> [NamedArg Pattern] -> Type -> Maybe Substitution -> [ProblemEq] -> (LHSResult -> TCM a) -> TCM a

-- | Result of checking the LHS of a clause.
data LHSResult
LHSResult :: Nat -> Telescope -> [NamedArg DeBruijnPattern] -> Bool -> Arg Type -> Substitution -> [AsBinding] -> IntSet -> Bool -> LHSResult

-- | The number of original module parameters. These are present in the the
--   patterns.
[lhsParameters] :: LHSResult -> Nat

-- | Δ : The types of the pattern variables, in internal dependency order.
--   Corresponds to <a>clauseTel</a>.
[lhsVarTele] :: LHSResult -> Telescope

-- | The patterns in internal syntax.
[lhsPatterns] :: LHSResult -> [NamedArg DeBruijnPattern]

-- | Whether the LHS has at least one absurd pattern.
[lhsHasAbsurd] :: LHSResult -> Bool

-- | The type of the body. Is <tt>bσ</tt> if <tt>Γ</tt> is defined.
--   <a>Irrelevant</a> to indicate the rhs must be checked in irrelevant
--   mode.
[lhsBodyType] :: LHSResult -> Arg Type

-- | Substitution version of <tt>lhsPatterns</tt>, only up to the first
--   projection pattern. <tt>Δ |- lhsPatSubst : Γ</tt>. Where <tt>Γ</tt> is
--   the argument telescope of the function. This is used to update
--   inherited dot patterns in with-function clauses.
[lhsPatSubst] :: LHSResult -> Substitution

-- | As-bindings from the left-hand side. Return instead of bound since we
--   want them in where's and right-hand sides, but not in with-clauses
--   (Issue 2303).
[lhsAsBindings] :: LHSResult -> [AsBinding]

-- | have we done a partial split?
[lhsPartialSplit] :: LHSResult -> IntSet

-- | have we split on an indexed type?
[lhsIndexedSplit] :: LHSResult -> Bool

-- | Bind as patterns
bindAsPatterns :: [AsBinding] -> TCM a -> TCM a

-- | A pattern is flexible if it is dotted or implicit, or a record pattern
--   with only flexible subpatterns.
class IsFlexiblePattern a
maybeFlexiblePattern :: (IsFlexiblePattern a, HasConstInfo m, MonadDebug m) => a -> MaybeT m FlexibleVarKind
isFlexiblePattern :: (IsFlexiblePattern a, HasConstInfo m, MonadDebug m) => a -> m Bool
type DataOrRecord = DataOrRecord' InductionAndEta
checkSortOfSplitVar :: (MonadTCM m, PureTCM m, MonadError TCErr m, LensSort a, PrettyTCM a, LensSort ty, PrettyTCM ty) => DataOrRecord -> a -> Telescope -> Maybe ty -> m ()
instance Agda.TypeChecking.Reduce.InstantiateFull Agda.TypeChecking.Rules.LHS.LHSResult
instance Agda.TypeChecking.Rules.LHS.IsFlexiblePattern Agda.Syntax.Abstract.Pattern
instance Agda.TypeChecking.Rules.LHS.IsFlexiblePattern (Agda.Syntax.Internal.Pattern' a)
instance Agda.TypeChecking.Rules.LHS.IsFlexiblePattern a => Agda.TypeChecking.Rules.LHS.IsFlexiblePattern [a]
instance Agda.TypeChecking.Rules.LHS.IsFlexiblePattern a => Agda.TypeChecking.Rules.LHS.IsFlexiblePattern (Agda.Syntax.Common.Arg a)
instance Agda.TypeChecking.Rules.LHS.IsFlexiblePattern a => Agda.TypeChecking.Rules.LHS.IsFlexiblePattern (Agda.Syntax.Common.Named name a)

module Agda.TypeChecking.Rules.Term

-- | Check that an expression is a type.
isType :: Expr -> Sort -> TCM Type

-- | Check that an expression is a type. * If <tt>c == CmpEq</tt>, the
--   given sort must be the minimal sort. * If <tt>c == CmpLeq</tt>, the
--   given sort may be any bigger sort.
isType' :: Comparison -> Expr -> Sort -> TCM Type

-- | Check that an expression is a type and infer its (minimal) sort.
isType_ :: Expr -> TCM Type
checkLevel :: NamedArg Expr -> TCM Level

-- | Ensure that a (freshly created) function type does not inhabit
--   <a>SizeUniv</a>. Precondition: When <tt>noFunctionsIntoSize t
--   tBlame</tt> is called, we are in the context of <tt>tBlame</tt> in
--   order to print it correctly. Not being in context of <tt>t</tt> should
--   not matter, as we are only checking whether its sort reduces to
--   <a>SizeUniv</a>.
--   
--   Currently UNUSED since SizeUniv is turned off (as of 2016).
--   
--   Check that an expression is a type which is equal to a given type.
isTypeEqualTo :: Expr -> Type -> TCM Type
leqType_ :: Type -> Type -> TCM ()
checkGeneralizeTelescope :: Maybe ModuleName -> GeneralizeTelescope -> ([Maybe Name] -> Telescope -> TCM a) -> TCM a

-- | Type check a (module) telescope. Binds the variables defined by the
--   telescope.
checkTelescope :: Telescope -> (Telescope -> TCM a) -> TCM a

-- | Type check the telescope of a dependent function type. Binds the
--   resurrected variables defined by the telescope. The returned telescope
--   is unmodified (not resurrected).
checkPiTelescope :: Telescope -> (Telescope -> TCM a) -> TCM a

-- | Flag to control resurrection on domains.
data LamOrPi

-- | We are checking a module telescope. We pass into the type world to
--   check the domain type. This resurrects the whole context.
LamNotPi :: LamOrPi

-- | We are checking a telescope in a Pi-type. We stay in the term world,
--   but add resurrected domains to the context to check the remaining
--   domains and codomain of the Pi-type.
PiNotLam :: LamOrPi

-- | Type check a telescope. Binds the variables defined by the telescope.
checkTelescope' :: LamOrPi -> Telescope -> (Telescope -> TCM a) -> TCM a

-- | Check the domain of a function type. Used in
--   <tt>checkTypedBindings</tt> and to typecheck <tt>A.Fun</tt> cases.
checkDomain :: (LensLock a, LensModality a) => LamOrPi -> List1 a -> Expr -> TCM Type
checkPiDomain :: (LensLock a, LensModality a) => List1 a -> Expr -> TCM Type

-- | Check a typed binding and extends the context with the bound
--   variables. The telescope passed to the continuation is valid in the
--   original context.
--   
--   Parametrized by a flag whether we check a typed lambda or a Pi. This
--   flag is needed for irrelevance.
checkTypedBindings :: LamOrPi -> TypedBinding -> (Telescope -> TCM a) -> TCM a

-- | After a typed binding has been checked, add the patterns it binds
addTypedPatterns :: List1 (NamedArg Binder) -> TCM a -> TCM a

-- | Check a tactic attribute. Should have type Term → TC ⊤.
checkTacticAttribute :: LamOrPi -> Ranged Expr -> TCM Term
checkPath :: NamedArg Binder -> Type -> Expr -> Type -> TCM Term

-- | Type check a lambda expression. "checkLambda bs e ty" means ( bs -&gt;
--   e) : ty
checkLambda :: Comparison -> TypedBinding -> Expr -> Type -> TCM Term
checkLambda' :: Comparison -> Range -> TypedBindingInfo -> List1 (NamedArg Binder) -> Type -> Expr -> Type -> TCM Term

-- | Check that modality info in lambda is compatible with modality coming
--   from the function type. If lambda has no user-given modality, copy
--   that of function type.
lambdaModalityCheck :: (LensAnnotation dom, LensModality dom) => dom -> ArgInfo -> TCM ArgInfo

-- | Check that irrelevance info in lambda is compatible with irrelevance
--   coming from the function type. If lambda has no user-given relevance,
--   copy that of function type.
lambdaIrrelevanceCheck :: LensRelevance dom => dom -> ArgInfo -> TCM ArgInfo

-- | Check that quantity info in lambda is compatible with quantity coming
--   from the function type. If lambda has no user-given quantity, copy
--   that of function type.
lambdaQuantityCheck :: LensQuantity dom => dom -> ArgInfo -> TCM ArgInfo
lambdaAnnotationCheck :: LensAnnotation dom => dom -> ArgInfo -> TCM ArgInfo

-- | Check that cohesion info in lambda is compatible with cohesion coming
--   from the function type. If lambda has no user-given cohesion, copy
--   that of function type.
lambdaCohesionCheck :: LensCohesion dom => dom -> ArgInfo -> TCM ArgInfo
lambdaAddContext :: MonadAddContext m => Name -> ArgName -> Dom Type -> m a -> m a

-- | Checking a lambda whose domain type has already been checked.
checkPostponedLambda :: Comparison -> Arg (List1 (WithHiding Name), Maybe Type) -> Expr -> Type -> TCM Term
checkPostponedLambda0 :: Comparison -> Arg ([WithHiding Name], Maybe Type) -> Expr -> Type -> TCM Term

-- | Insert hidden lambda until the hiding info of the domain type matches
--   the expected hiding info. Throws <a>WrongHidingInLambda</a>
insertHiddenLambdas :: Hiding -> Type -> (Blocker -> Type -> TCM Term) -> (Type -> TCM Term) -> TCM Term

-- | <tt>checkAbsurdLambda i h e t</tt> checks absurd lambda against type
--   <tt>t</tt>. Precondition: <tt>e = AbsurdLam i h</tt>
checkAbsurdLambda :: Comparison -> ExprInfo -> Hiding -> Expr -> Type -> TCM Term

-- | <tt>checkExtendedLambda i di erased qname cs e t</tt> check pattern
--   matching lambda. Precondition: <tt>e = ExtendedLam i di erased qname
--   cs</tt>
checkExtendedLambda :: Comparison -> ExprInfo -> DefInfo -> Erased -> QName -> List1 Clause -> Expr -> Type -> TCM Term

-- | Run a computation.
--   
--   <ul>
--   <li>If successful, that's it, we are done.</li>
--   <li>If <tt>NotADatatype a</tt> or <tt>CannotEliminateWithPattern p
--   a</tt> is thrown and type <tt>a</tt> is blocked on some meta
--   <tt>x</tt>, reset any changes to the state and pass (the error and)
--   <tt>x</tt> to the handler.</li>
--   <li>If <tt>SplitError (UnificationStuck c tel us vs _)</tt> is thrown
--   and the unification problem <tt>us =?= vs : tel</tt> is blocked on
--   some meta <tt>x</tt> pass <tt>x</tt> to the handler.</li>
--   <li>If another error was thrown or the type <tt>a</tt> is not blocked,
--   reraise the error.</li>
--   </ul>
--   
--   Note that the returned meta might only exists in the state where the
--   error was thrown, thus, be an invalid <a>MetaId</a> in the current
--   state.
catchIlltypedPatternBlockedOnMeta :: TCM a -> ((TCErr, Blocker) -> TCM a) -> TCM a

-- | Picks up record field assignments from modules that export a
--   definition that has the same name as the missing field.
expandModuleAssigns :: [Either Assign ModuleName] -> [Name] -> TCM Assigns

-- | <tt>checkRecordExpression fs e t</tt> checks record construction
--   against type <tt>t</tt>. Precondition <tt>e = Rec _ fs</tt>.
checkRecordExpression :: Comparison -> RecordAssigns -> Expr -> Type -> TCM Term

-- | <pre>
--   checkRecordUpdate cmp ei recexpr fs e t
--   </pre>
--   
--   Preconditions: <tt>e = RecUpdate ei recexpr fs</tt> and <tt>t</tt> is
--   reduced.
checkRecordUpdate :: Comparison -> ExprInfo -> Expr -> Assigns -> Expr -> Type -> TCM Term
checkLiteral :: Literal -> Type -> TCM Term

-- | Remove top layers of scope info of expression and set the scope
--   accordingly in the <a>TCState</a>.
scopedExpr :: Expr -> TCM Expr

-- | Type check an expression.
checkExpr :: Expr -> Type -> TCM Term
checkExpr' :: Comparison -> Expr -> Type -> TCM Term
doQuoteTerm :: Comparison -> Term -> Type -> TCM Term

-- | Unquote a TCM computation in a given hole.
unquoteM :: Expr -> Term -> Type -> TCM ()

-- | Run a tactic `tac : Term → TC ⊤` in a hole (second argument) of the
--   type given by the third argument. Runs the continuation if successful.
unquoteTactic :: Term -> Term -> Type -> TCM ()

-- | Check an interaction point without arguments.
checkQuestionMark :: (Comparison -> Type -> TCM (MetaId, Term)) -> Comparison -> Type -> MetaInfo -> InteractionId -> TCM Term

-- | Check an underscore without arguments.
checkUnderscore :: MetaInfo -> Comparison -> Type -> TCM Term

-- | Type check a meta variable.
checkMeta :: MetaInfo -> (Comparison -> Type -> TCM (MetaId, Term)) -> Comparison -> Type -> TCM Term

-- | Infer the type of a meta variable. If it is a new one, we create a new
--   meta for its type.
inferMeta :: MetaInfo -> (Comparison -> Type -> TCM (MetaId, Term)) -> TCM (Elims -> Term, Type)

-- | Type check a meta variable. If its type is not given, we return its
--   type, or a fresh one, if it is a new meta. If its type is given, we
--   check that the meta has this type, and we return the same type.
checkOrInferMeta :: MetaInfo -> (Comparison -> Type -> TCM (MetaId, Term)) -> Maybe (Comparison, Type) -> TCM (Term, Type)

-- | Turn a domain-free binding (e.g. lambda) into a domain-full one, by
--   inserting an underscore for the missing type.
domainFree :: ArgInfo -> Binder' Name -> LamBinding

-- | Check arguments whose value we already know.
--   
--   This function can be used to check user-supplied parameters we have
--   already computed by inference.
--   
--   Precondition: The type <tt>t</tt> of the head has enough domains.
checkKnownArguments :: [NamedArg Expr] -> Args -> Type -> TCM (Args, Type)

-- | Check an argument whose value we already know.
checkKnownArgument :: NamedArg Expr -> Args -> Type -> TCM (Args, Type)

-- | Check a single argument.
checkNamedArg :: NamedArg Expr -> Type -> TCM Term

-- | Infer the type of an expression. Implemented by checking against a
--   meta variable. Except for neutrals, for them a polymorphic type is
--   inferred.
inferExpr :: Expr -> TCM (Term, Type)
inferExpr' :: ExpandHidden -> Expr -> TCM (Term, Type)
defOrVar :: Expr -> Bool

-- | Used to check aliases <tt>f = e</tt>. Switches off <a>ExpandLast</a>
--   for the checking of top-level application.
checkDontExpandLast :: Comparison -> Expr -> Type -> TCM Term

-- | Check whether a de Bruijn index is bound by a module telescope.
isModuleFreeVar :: Int -> TCM Bool

-- | Infer the type of an expression, and if it is of the form <tt>{tel}
--   -&gt; D vs</tt> for some datatype <tt>D</tt> then insert the hidden
--   arguments. Otherwise, leave the type polymorphic.
inferExprForWith :: Arg Expr -> TCM (Term, Type)
checkLetBindings :: Foldable t => t LetBinding -> TCM a -> TCM a
checkLetBinding :: LetBinding -> TCM a -> TCM a
instance GHC.Show.Show Agda.TypeChecking.Rules.Term.LamOrPi
instance GHC.Classes.Eq Agda.TypeChecking.Rules.Term.LamOrPi

module Agda.TypeChecking.Rules.Builtin

-- | Bind a builtin thing to an expression.
bindBuiltin :: BuiltinId -> ResolvedName -> TCM ()

-- | Bind a builtin thing to a new name.
--   
--   Since their type is closed, it does not matter whether we are in a
--   parameterized module when we declare them. We simply ignore the
--   parameters.
bindBuiltinNoDef :: BuiltinId -> QName -> TCM ()
builtinKindOfName :: BuiltinId -> Maybe KindOfName

-- | <tt>bindPostulatedName builtin q m</tt> checks that <tt>q</tt> is a
--   postulated name, and binds the builtin <tt>builtin</tt> to the term
--   <tt>m q def</tt>, where <tt>def</tt> is the current <a>Definition</a>
--   of <tt>q</tt>.
bindPostulatedName :: BuiltinId -> ResolvedName -> (QName -> Definition -> TCM Term) -> TCM ()
isUntypedBuiltin :: BuiltinId -> Bool
bindUntypedBuiltin :: BuiltinId -> ResolvedName -> TCM ()


-- | Handling of the INFINITY, SHARP and FLAT builtins.
module Agda.TypeChecking.Rules.Builtin.Coinduction

-- | The type of <tt>∞</tt>.
typeOfInf :: TCM Type

-- | The type of <tt>♯_</tt>.
typeOfSharp :: TCM Type

-- | The type of <tt>♭</tt>.
typeOfFlat :: TCM Type

-- | Binds the INFINITY builtin, but does not change the type's definition.
bindBuiltinInf :: ResolvedName -> TCM ()

-- | Binds the SHARP builtin, and changes the definitions of INFINITY and
--   SHARP.
bindBuiltinSharp :: ResolvedName -> TCM ()

-- | Binds the FLAT builtin, and changes its definition.
bindBuiltinFlat :: ResolvedName -> TCM ()


-- | Coverage checking, case splitting, and splitting for refine tactics.
module Agda.TypeChecking.Coverage
data SplitClause
SClause :: Telescope -> [NamedArg SplitPattern] -> Substitution' SplitPattern -> Map CheckpointId Substitution -> Maybe (Dom Type) -> SplitClause

-- | Type of variables in <tt>scPats</tt>.
[scTel] :: SplitClause -> Telescope

-- | The patterns leading to the currently considered branch of the split
--   tree.
[scPats] :: SplitClause -> [NamedArg SplitPattern]

-- | Substitution from <a>scTel</a> to old context. Only needed directly
--   after split on variable: * To update <a>scTarget</a> * To rename other
--   split variables when splitting on multiple variables. <tt>scSubst</tt>
--   is not `<tt>transitive'</tt>, i.e., does not record the substitution
--   from the original context to <a>scTel</a> over a series of splits. It
--   is freshly computed after each split by <tt>computeNeighborhood</tt>;
--   also <tt>splitResult</tt>, which does not split on a variable, should
--   reset it to the identity <a>idS</a>, lest it be applied to
--   <a>scTarget</a> again, leading to Issue 1294.
[scSubst] :: SplitClause -> Substitution' SplitPattern

-- | We need to keep track of the module parameter checkpoints for the
--   clause for the purpose of inferring missing instance clauses.
[scCheckpoints] :: SplitClause -> Map CheckpointId Substitution

-- | The type of the rhs, living in context <a>scTel</a>.
--   <tt>fixTargetType</tt> computes the new <a>scTarget</a> by applying
--   substitution <a>scSubst</a>.
[scTarget] :: SplitClause -> Maybe (Dom Type)

-- | Create a split clause from a clause in internal syntax. Used by
--   make-case.
clauseToSplitClause :: Clause -> SplitClause

-- | Add more patterns to split clause if the target type is a function
--   type. Returns the domains of the function type (if any).
insertTrailingArgs :: Bool -> SplitClause -> TCM (Telescope, SplitClause)

-- | A <tt>Covering</tt> is the result of splitting a <a>SplitClause</a>.
data Covering
Covering :: Arg Nat -> [(SplitTag, (SplitClause, IInfo))] -> Covering

-- | De Bruijn level (counting dot patterns) of argument we split on.
[covSplitArg] :: Covering -> Arg Nat

-- | Covering clauses, indexed by constructor/literal these clauses share.
[covSplitClauses] :: Covering -> [(SplitTag, (SplitClause, IInfo))]

-- | Project the split clauses out of a covering.
splitClauses :: Covering -> [SplitClause]

-- | Top-level function for checking pattern coverage.
--   
--   Effects:
--   
--   <ul>
--   <li>Marks unreachable clauses as such in the signature.</li>
--   <li>Adds missing instances clauses to the signature.</li>
--   </ul>
coverageCheck :: QName -> Type -> [Clause] -> TCM SplitTree

-- | Top-level function for eliminating redundant clauses in the
--   interactive case splitter
isCovered :: QName -> [Clause] -> SplitClause -> TCM Bool

-- | Entry point from <tt>Interaction.MakeCase</tt>.
splitClauseWithAbsurd :: SplitClause -> Nat -> TCM (Either SplitError (Either SplitClause Covering))

-- | Entry point from <tt>TypeChecking.Empty</tt> and
--   <tt>Interaction.BasicOps</tt>. <tt>splitLast CoInductive</tt> is used
--   in the <tt>refine</tt> tactics.
splitLast :: Induction -> Telescope -> [NamedArg DeBruijnPattern] -> TCM (Either SplitError Covering)

-- | splitResult for MakeCase, tries to introduce IApply or ProjP
--   copatterns
splitResult :: QName -> SplitClause -> TCM (Either SplitError [SplitClause])
normaliseProjP :: (NormaliseProjP a, HasConstInfo m) => a -> m a
instance GHC.Show.Show Agda.TypeChecking.Coverage.InsertTrailing
instance GHC.Classes.Eq Agda.TypeChecking.Coverage.InsertTrailing
instance GHC.Show.Show Agda.TypeChecking.Coverage.AllowPartialCover
instance GHC.Classes.Eq Agda.TypeChecking.Coverage.AllowPartialCover
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.TypeChecking.Coverage.SplitClause.SplitClause

module Agda.TypeChecking.Empty

-- | Check whether a type is empty.
isEmptyType :: Type -> TCM Bool

-- | Check whether some type in a telescope is empty.
isEmptyTel :: Telescope -> TCM Bool

-- | Ensure that a type is empty. This check may be postponed as emptiness
--   constraint.
ensureEmptyType :: Range -> Type -> TCM ()

-- | Check whether one of the types in the given telescope is
--   constructor-less and if yes, return its index in the telescope (0 =
--   leftmost).
checkEmptyTel :: Range -> Telescope -> TCM (Either ErrorNonEmpty Int)
instance GHC.Base.Semigroup Agda.TypeChecking.Empty.ErrorNonEmpty
instance GHC.Base.Monoid Agda.TypeChecking.Empty.ErrorNonEmpty

module Agda.TypeChecking.CompiledClause.Compile
data RunRecordPatternTranslation
RunRecordPatternTranslation :: RunRecordPatternTranslation
DontRunRecordPatternTranslation :: RunRecordPatternTranslation
compileClauses' :: RunRecordPatternTranslation -> [Clause] -> Maybe SplitTree -> TCM CompiledClauses

-- | Process function clauses into case tree. This involves: 1. Coverage
--   checking, generating a split tree. 2. Translation of lhs record
--   patterns into rhs uses of projection. Update the split tree. 3.
--   Generating a case tree from the split tree. Phases 1. and 2. are
--   skipped if <tt>Nothing</tt>.
compileClauses :: Maybe (QName, Type) -> [Clause] -> TCM (Maybe SplitTree, Bool, CompiledClauses)

-- | Stripped-down version of <a>Clause</a> used in clause compiler.
data Cl
Cl :: [Arg Pattern] -> Maybe Term -> Cl

-- | Pattern variables are considered in left-to-right order.
[clPats] :: Cl -> [Arg Pattern]
[clBody] :: Cl -> Maybe Term
type Cls = [Cl]

-- | Strip down a clause. Don't forget to apply the substitution to the dot
--   patterns!
unBruijn :: Clause -> Cl
compileWithSplitTree :: SplitTree -> Cls -> CompiledClauses
compile :: Cls -> CompiledClauses

-- | Get the index of the next argument we need to split on. This the
--   number of the first pattern that does a (non-lazy) match in the first
--   clause. Or the first lazy match where all clauses agree on the
--   constructor, if there are no non-lazy matches.
nextSplit :: Cls -> Maybe (Bool, Arg Int)

-- | Is is not a variable pattern? And if yes, is it a record pattern
--   and/or a fallThrough one?
properSplit :: Pattern' a -> Maybe Bool

-- | Is this a variable pattern?
--   
--   Maintain invariant: <tt>isVar = isNothing . properSplit</tt>!
isVar :: Pattern' a -> Bool

-- | <tt>splitOn single n cs</tt> will force expansion of catch-alls if
--   <tt>single</tt>.
splitOn :: Bool -> Int -> Cls -> Case Cls
splitC :: Int -> Cl -> Case Cl

-- | Expand catch-alls that appear before actual matches.
--   
--   Example:
--   
--   <pre>
--   true  y
--   x     false
--   false y
--   </pre>
--   
--   will expand the catch-all <tt>x</tt> to <tt>false</tt>.
--   
--   Catch-alls need also to be expanded if they come before/after a record
--   pattern, otherwise we get into trouble when we want to eliminate
--   splits on records later.
--   
--   Another example (see Issue 1650): <tt> f (x, (y, z)) true = a f _
--   false = b </tt> Split tree: <tt> 0 (first argument of f) - 1 (second
--   component of the pair) - 3 (last argument of f) -- true -&gt; a -
--   false -&gt; b </tt> We would like to get the following case tree: <tt>
--   case 0 of _,_ -&gt; case 1 of _,_ -&gt; case 3 of true -&gt; a; false
--   -&gt; b _ -&gt; case 3 of true -&gt; a; false -&gt; b _ -&gt; case 3
--   of true -&gt; a; false -&gt; b </tt>
--   
--   Example from issue #2168: <tt> f x false = a f false = _ -&gt; b f x
--   true = c </tt> case tree: <tt> f x y = case y of true -&gt; case x of
--   true -&gt; c false -&gt; b false -&gt; a </tt>
--   
--   Example from issue #3628: <tt> f i j k (i = i0)(k = i1) = base f i j k
--   (j = i1) = base </tt> case tree: <tt> f i j k o = case i of i0 -&gt;
--   case k of i1 -&gt; base _ -&gt; case j of i1 -&gt; base _ -&gt; case j
--   of i1 -&gt; base </tt>
expandCatchAlls :: Bool -> Int -> Cls -> Cls

-- | Make sure (by eta-expansion) that clause has arity at least <tt>n</tt>
--   where <tt>n</tt> is also the length of the provided list.
ensureNPatterns :: Int -> [ArgInfo] -> Cl -> Cl
substBody :: Subst a => Int -> Int -> SubstArg a -> a -> a
instance GHC.Classes.Eq Agda.TypeChecking.CompiledClause.Compile.RunRecordPatternTranslation
instance GHC.Show.Show Agda.TypeChecking.CompiledClause.Compile.Cl
instance Agda.Syntax.Common.Pretty.Pretty Agda.TypeChecking.CompiledClause.Compile.Cl
instance Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars a => Agda.TypeChecking.Free.Precompute.PrecomputeFreeVars (Agda.TypeChecking.CompiledClause.CompiledClauses' a)

module Agda.TypeChecking.Rules.Record

-- | <pre>
--   checkRecDef i name con ps contel fields
--   </pre>
--   
--   <ul>
--   <li><i><tt>name</tt></i> Record type identifier.</li>
--   <li><i><tt>con</tt></i> Maybe constructor name and info.</li>
--   <li><i><tt>ps</tt></i> Record parameters.</li>
--   <li><i><tt>contel</tt></i> Approximate type of constructor
--   (<tt>fields</tt> -&gt; dummy). Does not include record
--   parameters.</li>
--   <li><i><tt>fields</tt></i> List of field signatures.</li>
--   </ul>
checkRecDef :: DefInfo -> QName -> UniverseCheck -> RecordDirectives -> DataDefParams -> Expr -> [Field] -> TCM ()
addCompositionForRecord :: QName -> EtaEquality -> ConHead -> Telescope -> [Arg QName] -> Telescope -> Type -> TCM ()
defineCompKitR :: QName -> Telescope -> Telescope -> [Arg QName] -> Type -> TCM CompKit
defineKanOperationR :: Command -> QName -> Telescope -> Telescope -> [Arg QName] -> Type -> TCM (Maybe QName)

-- | <tt>checkRecordProjections m r q tel ftel fs</tt>.
--   
--   <ul>
--   <li><i><tt>m</tt> </i> name of the generated module</li>
--   <li><i><tt>r</tt> </i> name of the record type</li>
--   <li><i><tt>con</tt> </i> name of the record constructor</li>
--   <li><i><tt>tel</tt> </i> parameters (perhaps erased) and record
--   variable r ("self")</li>
--   <li><i><tt>ftel</tt> </i> telescope of fields</li>
--   <li><i><tt>fs</tt> </i> the fields to be checked</li>
--   </ul>
checkRecordProjections :: ModuleName -> QName -> Bool -> ConHead -> Telescope -> Telescope -> [Declaration] -> TCM ()

module Agda.TypeChecking.Rules.Def
checkFunDef :: DefInfo -> QName -> [Clause] -> TCM ()
checkMacroType :: Type -> TCM ()

-- | A single clause without arguments and without type signature is an
--   alias.
isAlias :: [Clause] -> Type -> Maybe (Expr, Maybe Expr, MetaId)

-- | Check a trivial definition of the form <tt>f = e</tt>
checkAlias :: Type -> ArgInfo -> DefInfo -> QName -> Expr -> Maybe Expr -> TCM ()

-- | Type check a definition by pattern matching.
checkFunDef' :: Type -> ArgInfo -> Maybe ExtLamInfo -> Maybe QName -> DefInfo -> QName -> [Clause] -> TCM ()

-- | Type check a definition by pattern matching.
checkFunDefS :: Type -> ArgInfo -> Maybe ExtLamInfo -> Maybe QName -> DefInfo -> QName -> Maybe (Substitution, Map Name LetBinding) -> [Clause] -> TCM ()

-- | Set <a>funTerminates</a> according to termination info in
--   <a>TCEnv</a>, which comes from a possible termination pragma.
useTerPragma :: Definition -> TCM Definition

-- | Modify all the LHSCore of the given RHS. (Used to insert patterns for
--   <tt>rewrite</tt> or the inspect idiom)
mapLHSCores :: (LHSCore -> LHSCore) -> RHS -> RHS

-- | Insert some names into the with-clauses LHS of the given RHS. (Used
--   for the inspect idiom)
insertNames :: [Arg (Maybe BindName)] -> RHS -> RHS
insertInspects :: [Arg (Maybe BindName)] -> LHSCore -> LHSCore

-- | Insert some with-patterns into the with-clauses LHS of the given RHS.
--   (Used for <tt>rewrite</tt>)
insertPatterns :: [Arg Pattern] -> RHS -> RHS

-- | Insert with-patterns before the trailing with patterns. If there are
--   none, append the with-patterns.
insertPatternsLHSCore :: [Arg Pattern] -> LHSCore -> LHSCore

-- | Parameters for creating a <tt>with</tt>-function.
data WithFunctionProblem
NoWithFunction :: WithFunctionProblem
WithFunction :: QName -> QName -> Type -> Telescope -> Telescope -> Telescope -> [Arg (Term, EqualityView)] -> Type -> [NamedArg DeBruijnPattern] -> Nat -> Permutation -> Permutation -> Permutation -> List1 Clause -> Substitution -> Map Name LetBinding -> WithFunctionProblem

-- | Parent function name.
[wfParentName] :: WithFunctionProblem -> QName

-- | With function name.
[wfName] :: WithFunctionProblem -> QName

-- | Type of the parent function.
[wfParentType] :: WithFunctionProblem -> Type

-- | Context of the parent patterns.
[wfParentTel] :: WithFunctionProblem -> Telescope

-- | Types of arguments to the with function before the with expressions
--   (needed vars).
[wfBeforeTel] :: WithFunctionProblem -> Telescope

-- | Types of arguments to the with function after the with expressions
--   (unneeded vars).
[wfAfterTel] :: WithFunctionProblem -> Telescope

-- | With and rewrite expressions and their types.
[wfExprs] :: WithFunctionProblem -> [Arg (Term, EqualityView)]

-- | Type of the right hand side.
[wfRHSType] :: WithFunctionProblem -> Type

-- | Parent patterns.
[wfParentPats] :: WithFunctionProblem -> [NamedArg DeBruijnPattern]

-- | Number of module parameters in parent patterns
[wfParentParams] :: WithFunctionProblem -> Nat

-- | Permutation resulting from splitting the telescope into needed and
--   unneeded vars.
[wfPermSplit] :: WithFunctionProblem -> Permutation

-- | Permutation reordering the variables in the parent pattern.
[wfPermParent] :: WithFunctionProblem -> Permutation

-- | Final permutation (including permutation for the parent clause).
[wfPermFinal] :: WithFunctionProblem -> Permutation

-- | The given clauses for the with function
[wfClauses] :: WithFunctionProblem -> List1 Clause

-- | Subtsitution to generate call for the parent.
[wfCallSubst] :: WithFunctionProblem -> Substitution

-- | The let-bindings in scope of the parent (in the parent context)
[wfLetBindings] :: WithFunctionProblem -> Map Name LetBinding
checkSystemCoverage :: QName -> [Int] -> Type -> [Clause] -> TCM System
data ClausesPostChecks
CPC :: IntSet -> ClausesPostChecks

-- | Which argument indexes have a partial split.
[cpcPartialSplits] :: ClausesPostChecks -> IntSet

-- | The LHS part of checkClause.
checkClauseLHS :: Type -> Maybe Substitution -> SpineClause -> (LHSResult -> TCM a) -> TCM a

-- | Type check a function clause.
checkClause :: Type -> Maybe (Substitution, Map Name LetBinding) -> SpineClause -> TCM (Clause, ClausesPostChecks)

-- | Generate the abstract pattern corresponding to Refl
getReflPattern :: TCM Pattern

-- | Type check the <tt>with</tt> and <tt>rewrite</tt> lhss and/or the rhs.
checkRHS :: LHSInfo -> QName -> [NamedArg Pattern] -> Type -> LHSResult -> RHS -> TCM (Maybe Term, WithFunctionProblem)
checkWithRHS :: QName -> QName -> Type -> LHSResult -> [Arg (Term, EqualityView)] -> List1 Clause -> TCM (Maybe Term, WithFunctionProblem)

-- | Invoked in empty context.
checkWithFunction :: [Name] -> WithFunctionProblem -> TCM (Maybe Term)

-- | Type check a where clause.
checkWhere :: WhereDeclarations -> TCM a -> TCM a

-- | Enter a new section during type-checking.
newSection :: Erased -> ModuleName -> GeneralizeTelescope -> TCM a -> TCM a

-- | Set the current clause number.
atClause :: QName -> Int -> Type -> Maybe Substitution -> SpineClause -> TCM a -> TCM a
instance GHC.Base.Semigroup Agda.TypeChecking.Rules.Def.ClausesPostChecks
instance GHC.Base.Monoid Agda.TypeChecking.Rules.Def.ClausesPostChecks

module Agda.Interaction.MakeCase
type CaseContext = Maybe ExtLamInfo

-- | Parse variables (visible or hidden), returning their de Bruijn
--   indices. Used in <a>makeCase</a>.
parseVariables :: QName -> Context -> [AsBinding] -> InteractionId -> Range -> [String] -> TCM [(Int, NameInScope)]

-- | Lookup the clause for an interaction point in the signature. Returns
--   the CaseContext, the previous clauses, the clause itself, and a list
--   of the remaining ones.
type ClauseZipper = ([Clause], Clause, [Clause])
getClauseZipperForIP :: QName -> Int -> TCM (CaseContext, ClauseZipper)
recheckAbstractClause :: Type -> Maybe Substitution -> SpineClause -> TCM (Clause, Context, [AsBinding])

-- | Entry point for case splitting tactic.
makeCase :: InteractionId -> Range -> String -> TCM (QName, CaseContext, [Clause])

-- | Make the given pattern variables visible by marking their origin as
--   <a>CaseSplit</a> and pattern origin as <a>PatOSplit</a> in the
--   <a>SplitClause</a>.
makePatternVarsVisible :: [Nat] -> SplitClause -> SplitClause

-- | If a copattern split yields no clauses, we must be at an empty record
--   type. In this case, replace the rhs by <tt>record{}</tt>
makeRHSEmptyRecord :: RHS -> RHS

-- | Make clause with no rhs (because of absurd match).
makeAbsurdClause :: QName -> ExpandedEllipsis -> SplitClause -> TCM Clause

-- | Make a clause with a question mark as rhs.
makeAbstractClause :: QName -> RHS -> ExpandedEllipsis -> SplitClause -> TCM Clause
anyEllipsisVar :: QName -> SpineClause -> [Name] -> TCM Bool

module Agda.TypeChecking.Rules.Application

-- | <tt>checkArguments cmp exph r args t0 t k</tt> tries
--   <tt>checkArgumentsE exph args t0 t</tt>. If it succeeds, it continues
--   <tt>k</tt> with the returned results. If it fails, it registers a
--   postponed typechecking problem and returns the resulting new meta
--   variable.
--   
--   Checks <tt>e := ((_ : t0) args) : t</tt>.
checkArguments :: Comparison -> ExpandHidden -> Range -> [NamedArg Expr] -> Type -> Type -> (ArgsCheckState CheckedTarget -> TCM Term) -> TCM Term

-- | Check that a list of arguments fits a telescope. Inserts hidden
--   arguments as necessary. Returns the type-checked arguments and the
--   remaining telescope.
checkArguments_ :: Comparison -> ExpandHidden -> Range -> [NamedArg Expr] -> Telescope -> TCM (Elims, Telescope)

-- | <tt>checkApplication hd args e t</tt> checks an application.
--   Precondition: <tt>Application hs args = appView e</tt>
--   
--   <tt>checkApplication</tt> disambiguates constructors (and continues to
--   <a>checkConstructorApplication</a>) and resolves pattern synonyms.
checkApplication :: Comparison -> Expr -> Args -> Expr -> Type -> TCM Term

-- | Precondition: <tt>Application hd args = appView e</tt>.
inferApplication :: ExpandHidden -> Expr -> Args -> Expr -> TCM (Term, Type)

-- | Checking the type of an overloaded projection application. See
--   <a>inferOrCheckProjAppToKnownPrincipalArg</a>.
checkProjAppToKnownPrincipalArg :: Comparison -> Expr -> ProjOrigin -> List1 QName -> Args -> Type -> Int -> Term -> Type -> PrincipalArgTypeMetas -> TCM Term
univChecks :: Univ -> TCM ()
suffixToLevel :: Suffix -> Integer

module Agda.TypeChecking.Rules.Decl

-- | Cached checkDecl
checkDeclCached :: Declaration -> TCM ()

-- | Type check a sequence of declarations.
checkDecls :: [Declaration] -> TCM ()

-- | Type check a single declaration.
checkDecl :: Declaration -> TCM ()
mutualChecks :: MutualInfo -> Declaration -> [Declaration] -> MutualId -> Set QName -> TCM ()

-- | Check if there is a inferred eta record type in the mutual block. If
--   yes, repeat the record pattern translation for all function
--   definitions in the block. This is necessary since the original record
--   pattern translation will have skipped record patterns of the new
--   record types (as eta was off for them). See issue #2308 (and #2197).
revisitRecordPatternTranslation :: [QName] -> TCM ()
type FinalChecks = Maybe (TCM ())
checkUnquoteDecl :: MutualInfo -> [DefInfo] -> [QName] -> Expr -> TCM FinalChecks
checkUnquoteDef :: [DefInfo] -> [QName] -> Expr -> TCM ()

-- | Run a reflected TCM computatation expected to define a given list of
--   names.
unquoteTop :: [QName] -> Expr -> TCM [QName]

-- | Instantiate all metas in <a>Definition</a> associated to <a>QName</a>.
--   Makes sense after freezing metas. Some checks, like free variable
--   analysis, are not in <a>TCMT</a>, so they will be more precise (see
--   issue 1099) after meta instantiation. Precondition: name has been
--   added to signature already.
instantiateDefinitionType :: QName -> TCM ()
data HighlightModuleContents
DontHightlightModuleContents :: HighlightModuleContents
DoHighlightModuleContents :: HighlightModuleContents

-- | Highlight a declaration. Called after checking a mutual block (to
--   ensure we have the right definitions for all names). For modules
--   inside mutual blocks we haven't highlighted their contents, but for
--   modules not in a mutual block we have. Hence the flag.
highlight_ :: HighlightModuleContents -> Declaration -> TCM ()

-- | Termination check a declaration.
checkTermination_ :: Declaration -> TCM ()

-- | Check a set of mutual names for positivity.
checkPositivity_ :: MutualInfo -> Set QName -> TCM ()

-- | Check that all coinductive records are actually recursive. (Otherwise,
--   one can implement invalid recursion schemes just like for the old
--   coinduction.)
checkCoinductiveRecords :: [Declaration] -> TCM ()

-- | Check a set of mutual names for constructor-headedness.
checkInjectivity_ :: Set QName -> TCM ()

-- | Check a set of mutual names for projection likeness.
--   
--   Only a single, non-abstract function can be projection-like. Making an
--   abstract function projection-like would break the invariant that the
--   type of the principle argument of a projection-like function is always
--   inferable.
checkProjectionLikeness_ :: Set QName -> TCM ()

-- | Freeze metas created by given computation if in abstract mode.
whenAbstractFreezeMetasAfter :: DefInfo -> TCM a -> TCM a
checkGeneralize :: Set QName -> DefInfo -> ArgInfo -> QName -> Expr -> TCM ()

-- | Type check an axiom.
checkAxiom :: KindOfName -> DefInfo -> ArgInfo -> Maybe [Occurrence] -> QName -> Expr -> TCM ()

-- | Data and record type signatures need to remember the generalized
--   parameters for when checking the corresponding definition, so for
--   these we pass in the parameter telescope separately.
checkAxiom' :: Maybe GeneralizeTelescope -> KindOfName -> DefInfo -> ArgInfo -> Maybe [Occurrence] -> QName -> Expr -> TCM ()

-- | Type check a primitive function declaration.
checkPrimitive :: DefInfo -> QName -> Arg Expr -> TCM ()

-- | Check a pragma.
checkPragma :: Range -> Pragma -> TCM ()

-- | Type check a bunch of mutual inductive recursive definitions.
--   
--   All definitions which have so far been assigned to the given mutual
--   block are returned.
checkMutual :: MutualInfo -> [Declaration] -> TCM (MutualId, Set QName)
checkSig :: KindOfName -> DefInfo -> Erased -> QName -> GeneralizeTelescope -> Expr -> TCM ()

-- | Type check the type signature of an inductive or recursive definition.
checkTypeSignature :: TypeSignature -> TCM ()
checkTypeSignature' :: Maybe GeneralizeTelescope -> TypeSignature -> TCM ()

-- | Type check a module.
checkSection :: Erased -> ModuleName -> GeneralizeTelescope -> [Declaration] -> TCM ()

-- | Helper for <a>checkSectionApplication</a>.
--   
--   Matches the arguments of the module application with the module
--   parameters.
--   
--   Returns the remaining module parameters as an open telescope. Warning:
--   the returned telescope is <i>not</i> the final result, an actual
--   instantiation of the parameters does not occur.
checkModuleArity :: ModuleName -> Telescope -> [NamedArg Expr] -> TCM Telescope

-- | Check an application of a section.
checkSectionApplication :: ModuleInfo -> Erased -> ModuleName -> ModuleApplication -> ScopeCopyInfo -> ImportDirective -> TCM ()

-- | Check an application of a section. (Do not invoke this procedure
--   directly, use <a>checkSectionApplication</a>.)
checkSectionApplication' :: ModuleInfo -> Erased -> ModuleName -> ModuleApplication -> ScopeCopyInfo -> TCM ()

-- | Checks that <tt>open public</tt> is not used in hard compile-time
--   mode.
checkImportDirective :: ImportDirective -> TCM ()
class ShowHead a
showHead :: ShowHead a => a -> String
debugPrintDecl :: Declaration -> TCM ()
instance GHC.Classes.Eq Agda.TypeChecking.Rules.Decl.HighlightModuleContents
instance Agda.TypeChecking.Rules.Decl.ShowHead Agda.Syntax.Abstract.Declaration

module Agda.TheTypeChecker

-- | Type check a sequence of declarations.
checkDecls :: [Declaration] -> TCM ()

-- | Type check a single declaration.
checkDecl :: Declaration -> TCM ()

-- | Cached checkDecl
checkDeclCached :: Declaration -> TCM ()

-- | Infer the type of an expression. Implemented by checking against a
--   meta variable. Except for neutrals, for them a polymorphic type is
--   inferred.
inferExpr :: Expr -> TCM (Term, Type)

-- | Type check an expression.
checkExpr :: Expr -> Type -> TCM Term


-- | Common syntax highlighting functions for Emacs and JSON
module Agda.Interaction.Highlighting.Common

-- | Converts the <a>aspect</a> and <a>otherAspects</a> fields to strings
--   that are friendly to editors.
toAtoms :: Aspects -> [String]

-- | Choose which method to use based on HighlightingInfo and
--   HighlightingMethod
chooseHighlightingMethod :: HighlightingInfo -> HighlightingMethod -> HighlightingMethod


-- | Functions which give precise syntax highlighting info in JSON format.
module Agda.Interaction.Highlighting.JSON

-- | Turns syntax highlighting information into a JSON value
jsonifyHighlightingInfo :: HighlightingInfo -> RemoveTokenBasedHighlighting -> HighlightingMethod -> ModuleToSource -> IO Value
instance Agda.Interaction.JSON.EncodeTCM Agda.Syntax.Common.Aspect.TokenBased
instance Data.Aeson.Types.ToJSON.ToJSON Agda.Syntax.Common.Aspect.TokenBased


-- | Functions which give precise syntax highlighting info to Emacs.
module Agda.Interaction.Highlighting.Emacs

-- | Turns syntax highlighting information into a list of S-expressions.
lispifyHighlightingInfo :: HighlightingInfo -> RemoveTokenBasedHighlighting -> HighlightingMethod -> ModuleToSource -> IO (Lisp String)

-- | Formats the <a>TokenBased</a> tag for the Emacs backend. No quotes are
--   added.
lispifyTokenBased :: TokenBased -> Lisp String

module Agda.Compiler.Treeless.Unused
usedArguments :: QName -> TTerm -> TCM [ArgUsage]
stripUnusedArguments :: [ArgUsage] -> TTerm -> TTerm

module Agda.Compiler.Treeless.Simplify
simplifyTTerm :: TTerm -> TCM TTerm
instance GHC.Classes.Ord Agda.Compiler.Treeless.Simplify.Atom
instance GHC.Classes.Eq Agda.Compiler.Treeless.Simplify.Atom
instance GHC.Show.Show Agda.Compiler.Treeless.Simplify.Atom


-- | Ensures that all occurences of an abstract name share the same
--   concrete name.
--   
--   Apply this transformation if your backend uses concrete names for
--   identification purposes!
--   
--   The identity of an abstract name is only the nameId, the concrete name
--   is only a naming suggestion. If renaming imports are used, the
--   concrete name may change. This transformation makes sure that all
--   occurences of an abstract name share the same concrete name.
--   
--   This transfomation should be run as the last transformation.
module Agda.Compiler.Treeless.NormalizeNames
normalizeNames :: TTerm -> TCM TTerm

module Agda.Compiler.Treeless.Identity
detectIdentityFunctions :: QName -> TTerm -> TCM TTerm
instance GHC.Base.Semigroup Agda.Compiler.Treeless.Identity.IdentityIn

module Agda.Compiler.Treeless.Erase
eraseTerms :: QName -> EvaluationStrategy -> TTerm -> TCM TTerm

-- | Takes the name of the data/record type.
computeErasedConstructorArgs :: QName -> TCM ()
isErasable :: QName -> TCM Bool
instance GHC.Show.Show Agda.Compiler.Treeless.Erase.TypeInfo
instance GHC.Classes.Eq Agda.Compiler.Treeless.Erase.TypeInfo


-- | Converts case matches on literals to if cascades with equality
--   comparisons.
module Agda.Compiler.Treeless.EliminateLiteralPatterns
eliminateLiteralPatterns :: TTerm -> TCM TTerm
data BuiltinKit
BuiltinKit :: Maybe QName -> Maybe QName -> BuiltinKit
[nat] :: BuiltinKit -> Maybe QName
[int] :: BuiltinKit -> Maybe QName
transform :: BuiltinKit -> TTerm -> TTerm


-- | Eliminates case defaults by adding an alternative for all possible
--   constructors. Literal cases are preserved as-is.
module Agda.Compiler.Treeless.EliminateDefaults
eliminateCaseDefaults :: TTerm -> TCM TTerm


-- | Translates the Agda builtin nat datatype to arbitrary-precision
--   integers.
--   
--   Philipp, 20150921: At the moment, this optimization is the reason that
--   there is a TAPlus alternative. For Haskell, this can easily be
--   translated to guards. However, in the long term it would be easier for
--   the backends if these things were translated directly to a less-than
--   primitive and if-then-else expressions or similar. This would require
--   us to add some internal Bool-datatype as compiler-internal type and a
--   primitive less-than function, which will be much easier once Treeless
--   is used for whole modules.
--   
--   Ulf, 2015-09-21: No, actually we need the n+k patterns, or at least
--   guards. Representing them with if-then-else would make it a lot harder
--   to do optimisations that analyse case tree, like impossible case
--   elimination.
--   
--   Ulf, 2015-10-30: Guards are actually a better primitive. Fixed that.
module Agda.Compiler.Treeless.Builtin
translateBuiltins :: TTerm -> TCM TTerm

module Agda.Compiler.ToTreeless
toTreeless :: EvaluationStrategy -> QName -> TCM (Maybe TTerm)

-- | Converts compiled clauses to treeless syntax.
--   
--   Note: Do not use any of the concrete names in the returned term for
--   identification purposes! If you wish to do so, first apply the
--   Agda.Compiler.Treeless.NormalizeNames transformation.
toTreelessWith :: BuildPipeline -> CCConfig -> QName -> TCM (Maybe TTerm)
closedTermToTreeless :: CCConfig -> Term -> TCM TTerm
data Pipeline
FixedPoint :: Int -> Pipeline -> Pipeline
Sequential :: [Pipeline] -> Pipeline
SinglePass :: CompilerPass -> Pipeline
data CompilerPass
CompilerPass :: String -> Int -> String -> (EvaluationStrategy -> TTerm -> TCM TTerm) -> CompilerPass
[passTag] :: CompilerPass -> String
[passVerbosity] :: CompilerPass -> Int
[passName] :: CompilerPass -> String
[passCode] :: CompilerPass -> EvaluationStrategy -> TTerm -> TCM TTerm
compilerPass :: String -> Int -> String -> (EvaluationStrategy -> TTerm -> TCM TTerm) -> Pipeline
instance GHC.Classes.Eq Agda.Compiler.ToTreeless.CCSubst

module Agda.Compiler.MAlonzo.Coerce

-- | Insert unsafeCoerce (in the form of <a>TCoerce</a>) everywhere it's
--   needed in the right-hand side of a definition.
addCoercions :: HasConstInfo m => TTerm -> m TTerm

-- | The number of retained arguments after erasure.
erasedArity :: HasConstInfo m => QName -> m Nat


-- | A command which calls a compiler
module Agda.Compiler.CallCompiler

-- | Calls a compiler:
--   
--   <ul>
--   <li>Checks the exit code to see if the compiler exits successfully. If
--   not, then an exception is raised, containing the text the compiler
--   printed to stderr (if any).</li>
--   <li>Uses the debug printout machinery to relay any progress
--   information the compiler prints to stdout.</li>
--   </ul>
callCompiler :: Bool -> FilePath -> [String] -> Maybe FilePath -> Maybe TextEncoding -> TCM ()

-- | Generalisation of <tt>callCompiler</tt> where the raised exception is
--   returned.
callCompiler' :: FilePath -> [String] -> Maybe FilePath -> Maybe TextEncoding -> TCM (Maybe String)


-- | Translation from <a>Agda.Syntax.Concrete</a> to
--   <a>Agda.Syntax.Abstract</a>. Involves scope analysis, figuring out
--   infix operator precedences and tidying up definitions.
module Agda.Syntax.Translation.ConcreteToAbstract

-- | Things that can be translated to abstract syntax are instances of this
--   class.
class ToAbstract c where {
    type AbsOfCon c;
}
toAbstract :: ToAbstract c => c -> ScopeM (AbsOfCon c)

-- | This operation does not affect the scope, i.e. the original scope is
--   restored upon completion.
localToAbstract :: ToAbstract c => c -> (AbsOfCon c -> ScopeM b) -> ScopeM b
concreteToAbstract_ :: ToAbstract c => c -> ScopeM (AbsOfCon c)
concreteToAbstract :: ToAbstract c => ScopeInfo -> c -> ScopeM (AbsOfCon c)
newtype NewModuleQName
NewModuleQName :: QName -> NewModuleQName

-- | Temporary data type to scope check a file.
data TopLevel a
TopLevel :: AbsolutePath -> TopLevelModuleName -> a -> TopLevel a

-- | The file path from which we loaded this module.
[topLevelPath] :: TopLevel a -> AbsolutePath

-- | The expected module name (coming from the import statement that
--   triggered scope checking this file).
[topLevelExpectedName] :: TopLevel a -> TopLevelModuleName

-- | The file content.
[topLevelTheThing] :: TopLevel a -> a
data TopLevelInfo
TopLevelInfo :: [Declaration] -> ScopeInfo -> TopLevelInfo
[topLevelDecls] :: TopLevelInfo -> [Declaration]

-- | as seen from inside the module
[topLevelScope] :: TopLevelInfo -> ScopeInfo

-- | The top-level module name.
topLevelModuleName :: TopLevelInfo -> ModuleName
data AbstractRHS
data NewModuleName
data OldModuleName
data NewName a
data OldQName
data PatName
data APatName

-- | Declaration <tt>open import Agda.Primitive using (Set)</tt> when
--   <a>optImportSorts</a>. <tt>Prop</tt> is added when <a>optProp</a>, and
--   <tt>SSet</tt> when <a>optTwoLevel</a>.
importPrimitives :: ScopeM [Declaration]

-- | Raises an error if the list of attributes contains an unsupported
--   attribute.
checkAttributes :: Attributes -> ScopeM ()
instance GHC.Base.Functor Agda.Syntax.Translation.ConcreteToAbstract.NewName
instance GHC.Show.Show Agda.Syntax.Translation.ConcreteToAbstract.TerminationOrPositivity
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (Agda.Syntax.Translation.ConcreteToAbstract.WithHidingInfo Agda.Syntax.Concrete.Pattern)
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Concrete.Pragma
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Concrete.Definitions.Types.Clause
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Translation.ConcreteToAbstract.LeftHandSide
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Translation.ConcreteToAbstract.AbstractRHS
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Translation.ConcreteToAbstract.RightHandSide
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Concrete.RHS
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Concrete.Definitions.Types.NiceDeclaration
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Translation.ConcreteToAbstract.DataConstrDecl
instance Agda.Syntax.Translation.ConcreteToAbstract.LivesInCurrentModule Agda.Syntax.Scope.Base.AbstractName
instance Agda.Syntax.Translation.ConcreteToAbstract.LivesInCurrentModule Agda.Syntax.Abstract.Name.QName
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Translation.ConcreteToAbstract.GenTelAndType
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Translation.ConcreteToAbstract.GenTel
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Translation.ConcreteToAbstract.LetDefs
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Translation.ConcreteToAbstract.LetDef
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Concrete.Expr
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Concrete.TypedBinding
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (Agda.Syntax.Translation.ConcreteToAbstract.TopLevel [Agda.Syntax.Concrete.Declaration])
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Translation.ConcreteToAbstract.Declarations
instance Agda.Syntax.Translation.ConcreteToAbstract.EnsureNoLetStms Agda.Syntax.Concrete.Binder
instance Agda.Syntax.Translation.ConcreteToAbstract.EnsureNoLetStms Agda.Syntax.Concrete.TypedBinding
instance Agda.Syntax.Translation.ConcreteToAbstract.EnsureNoLetStms a => Agda.Syntax.Translation.ConcreteToAbstract.EnsureNoLetStms (Agda.Syntax.Concrete.LamBinding' a)
instance Agda.Syntax.Translation.ConcreteToAbstract.EnsureNoLetStms a => Agda.Syntax.Translation.ConcreteToAbstract.EnsureNoLetStms (Agda.Syntax.Common.Named_ a)
instance Agda.Syntax.Translation.ConcreteToAbstract.EnsureNoLetStms a => Agda.Syntax.Translation.ConcreteToAbstract.EnsureNoLetStms (Agda.Syntax.Common.NamedArg a)
instance Agda.Syntax.Translation.ConcreteToAbstract.EnsureNoLetStms a => Agda.Syntax.Translation.ConcreteToAbstract.EnsureNoLetStms [a]
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Translation.ConcreteToAbstract.OldModuleName
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Concrete.ModuleAssignment
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Translation.ConcreteToAbstract.NewModuleQName
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Translation.ConcreteToAbstract.NewModuleName
instance Agda.Syntax.Translation.ConcreteToAbstract.ToQName Agda.Syntax.Concrete.Name.Name
instance Agda.Syntax.Translation.ConcreteToAbstract.ToQName Agda.Syntax.Concrete.Name.QName
instance Agda.Syntax.Translation.ConcreteToAbstract.ToQName a => Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (Agda.Syntax.Translation.ConcreteToAbstract.OldName a)
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Translation.ConcreteToAbstract.PatName
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Concrete.Pattern
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Translation.ConcreteToAbstract.ResolveQName
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Concrete.LHSCore
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Translation.ConcreteToAbstract.OldQName
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Translation.ConcreteToAbstract.MaybeOldQName
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (Agda.Syntax.Translation.ConcreteToAbstract.NewName Agda.Syntax.Concrete.Name.Name)
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (Agda.Syntax.Translation.ConcreteToAbstract.NewName Agda.Syntax.Concrete.BoundName)
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (Agda.Syntax.Concrete.Binder' (Agda.Syntax.Translation.ConcreteToAbstract.NewName Agda.Syntax.Concrete.BoundName))
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Concrete.LamBinding
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Concrete.RewriteEqn
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Translation.ConcreteToAbstract.RecordConstructorType
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract ()
instance (Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract c1, Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract c2) => Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (c1, c2)
instance (Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract c1, Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract c2, Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract c3) => Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (c1, c2, c3)
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract c => Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract [c]
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract c => Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (Agda.Utils.List1.List1 c)
instance (Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract c1, Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract c2) => Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (Data.Either.Either c1 c2)
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract c => Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (GHC.Maybe.Maybe c)
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract c => Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (Agda.Syntax.Concrete.FieldAssignment' c)
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (Agda.Syntax.Common.RewriteEqn' () Agda.Syntax.Abstract.BindName Agda.Syntax.Abstract.Pattern Agda.Syntax.Abstract.Expr)
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract c => Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (Agda.Syntax.Common.WithHiding c)
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract c => Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (Agda.Syntax.Common.Arg c)
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract c => Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (Agda.Syntax.Common.Named name c)
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract c => Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (Agda.Syntax.Common.Ranged c)
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (Agda.Syntax.Abstract.LHSCore' Agda.Syntax.Concrete.Expr)
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract (Agda.Syntax.Abstract.Pattern' Agda.Syntax.Concrete.Expr)
instance Agda.Syntax.Translation.ConcreteToAbstract.ToAbstract Agda.Syntax.Concrete.HoleContent

module Agda.Interaction.BasicOps

-- | Parses an expression.
parseExpr :: Range -> String -> TCM Expr
parseExprIn :: InteractionId -> Range -> String -> TCM Expr
giveExpr :: UseForce -> Maybe InteractionId -> MetaId -> Expr -> TCM Term

-- | After a give, redo termination etc. checks for function which was
--   complemented.
redoChecks :: Maybe InteractionId -> TCM ()

-- | Try to fill hole by expression.
--   
--   Returns the given expression unchanged (for convenient generalization
--   to <tt><a>refine</a></tt>).
give :: UseForce -> InteractionId -> Maybe Range -> Expr -> TCM Expr

-- | Try to fill hole by elaborated expression.
elaborate_give :: Rewrite -> UseForce -> InteractionId -> Maybe Range -> Expr -> TCM Expr

-- | Try to refine hole by expression <tt>e</tt>.
--   
--   This amounts to successively try to give <tt>e</tt>, <tt>e ?</tt>,
--   <tt>e ? ?</tt>, ... Returns the successfully given expression.
refine :: UseForce -> InteractionId -> Maybe Range -> Expr -> TCM Expr

-- | Evaluate the given expression in the current environment
evalInCurrent :: ComputeMode -> Expr -> TCM Expr
evalInMeta :: InteractionId -> ComputeMode -> Expr -> TCM Expr

-- | Modifier for interactive commands, specifying the amount of
--   normalization in the output.
normalForm :: (Reduce t, Simplify t, Instantiate t, Normalise t) => Rewrite -> t -> TCM t

-- | Modifier for the interactive computation command, specifying the mode
--   of computation and result display.
computeIgnoreAbstract :: ComputeMode -> Bool
computeWrapInput :: ComputeMode -> String -> String
showComputed :: ComputeMode -> Expr -> TCM Doc

-- | Modifier for interactive commands, specifying whether safety checks
--   should be ignored.
outputFormId :: OutputForm a b -> b
reifyElimToExpr :: MonadReify m => Elim -> m Expr
prettyConstraints :: [Closure Constraint] -> TCM [OutputForm Expr Expr]
getConstraints :: TCM [OutputForm Expr Expr]
namedMetaOf :: OutputConstraint Expr a -> a
getConstraintsMentioning :: Rewrite -> MetaId -> TCM [OutputForm Expr Expr]
stripConstraintPids :: Constraints -> Constraints

-- | Converts an <a>InteractionId</a> to a <a>MetaId</a>.
interactionIdToMetaId :: ReadTCState m => InteractionId -> m MetaId
getConstraints' :: (ProblemConstraint -> TCM ProblemConstraint) -> (ProblemConstraint -> Bool) -> TCM [OutputForm Expr Expr]

-- | Reify the boundary of an interaction point as something that can be
--   shown to the user.
getIPBoundary :: Rewrite -> InteractionId -> TCM [IPFace' Expr]
typeAndFacesInMeta :: InteractionId -> Rewrite -> Expr -> TCM (Expr, [IPFace' Expr])

-- | Goals and Warnings
getGoals :: TCM Goals
getGoals' :: Rewrite -> Rewrite -> TCM Goals

-- | Print open metas nicely.
showGoals :: Goals -> TCM String
getWarningsAndNonFatalErrors :: TCM WarningsAndNonFatalErrors

-- | Collecting the context of the given meta-variable.
getResponseContext :: Rewrite -> InteractionId -> TCM [ResponseContextEntry]

-- | <tt>getSolvedInteractionPoints True</tt> returns all solutions, even
--   if just solved by another, non-interaction meta.
--   
--   <tt>getSolvedInteractionPoints False</tt> only returns metas that are
--   solved by a non-meta.
getSolvedInteractionPoints :: Bool -> Rewrite -> TCM [(InteractionId, MetaId, Expr)]
typeOfMetaMI :: Rewrite -> MetaId -> TCM (OutputConstraint Expr NamedMeta)
typeOfMeta :: Rewrite -> InteractionId -> TCM (OutputConstraint Expr InteractionId)
typeOfMeta' :: Rewrite -> (InteractionId, MetaId) -> TCM (OutputConstraint Expr InteractionId)
typesOfVisibleMetas :: Rewrite -> TCM [OutputConstraint Expr InteractionId]
typesOfHiddenMetas :: Rewrite -> TCM [OutputConstraint Expr NamedMeta]

-- | Create type of application of new helper function that would solve the
--   goal.
metaHelperType :: Rewrite -> InteractionId -> Range -> String -> TCM (OutputConstraint' Expr Expr)

-- | Gives a list of names and corresponding types. This list includes not
--   only the local variables in scope, but also the let-bindings.
contextOfMeta :: InteractionId -> Rewrite -> TCM [ResponseContextEntry]

-- | Returns the type of the expression in the current environment We wake
--   up irrelevant variables just in case the user want to invoke that
--   command in an irrelevant context.
typeInCurrent :: Rewrite -> Expr -> TCM Expr
typeInMeta :: InteractionId -> Rewrite -> Expr -> TCM Expr

-- | The intro tactic.
--   
--   Returns the terms (as strings) that can be used to refine the goal.
--   Uses the coverage checker to find out which constructors are possible.
introTactic :: Bool -> InteractionId -> TCM [String]

-- | Runs the given computation as if in an anonymous goal at the end of
--   the top-level module.
--   
--   Sets up current module, scope, and context.
atTopLevel :: TCM a -> TCM a

-- | Parse a name.
parseName :: Range -> String -> TCM QName

-- | Check whether an expression is a (qualified) identifier.
isQName :: Expr -> Maybe QName
isName :: Expr -> Maybe Name

-- | Returns the contents of the given module or record.
moduleContents :: Rewrite -> Range -> String -> TCM ([Name], Telescope, [(Name, Type)])

-- | Returns the contents of the given record identifier.
getRecordContents :: Rewrite -> Expr -> TCM ([Name], Telescope, [(Name, Type)])

-- | Returns the contents of the given module.
getModuleContents :: Rewrite -> Maybe QName -> TCM ([Name], Telescope, [(Name, Type)])
whyInScope :: FilePath -> String -> TCM WhyInScopeData
instance Agda.Syntax.Translation.InternalToAbstract.Reify Agda.TypeChecking.Monad.Base.ProblemConstraint
instance Agda.Syntax.Translation.InternalToAbstract.Reify Agda.TypeChecking.Monad.Base.Constraint
instance (Agda.Syntax.Common.Pretty.Pretty a, Agda.Syntax.Common.Pretty.Pretty b) => Agda.TypeChecking.Pretty.PrettyTCM (Agda.Interaction.Output.OutputForm a b)
instance (Agda.Syntax.Common.Pretty.Pretty a, Agda.Syntax.Common.Pretty.Pretty b) => Agda.Syntax.Common.Pretty.Pretty (Agda.Interaction.Output.OutputForm a b)
instance (Agda.Syntax.Common.Pretty.Pretty a, Agda.Syntax.Common.Pretty.Pretty b) => Agda.Syntax.Common.Pretty.Pretty (Agda.Interaction.Output.OutputConstraint a b)
instance (Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a, Agda.Syntax.Translation.AbstractToConcrete.ToConcrete b) => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Interaction.Output.OutputForm a b)
instance (Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a, Agda.Syntax.Translation.AbstractToConcrete.ToConcrete b) => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Interaction.Output.OutputConstraint a b)
instance (Agda.Syntax.Common.Pretty.Pretty a, Agda.Syntax.Common.Pretty.Pretty b) => Agda.Syntax.Common.Pretty.Pretty (Agda.Interaction.Base.OutputConstraint' a b)
instance (Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a, Agda.Syntax.Translation.AbstractToConcrete.ToConcrete b) => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.Interaction.Base.OutputConstraint' a b)
instance Agda.Syntax.Translation.InternalToAbstract.Reify a => Agda.Syntax.Translation.InternalToAbstract.Reify (Agda.TypeChecking.Monad.Base.IPBoundary' a)
instance Agda.Syntax.Translation.AbstractToConcrete.ToConcrete a => Agda.Syntax.Translation.AbstractToConcrete.ToConcrete (Agda.TypeChecking.Monad.Base.IPBoundary' a)
instance Agda.Syntax.Common.Pretty.Pretty c => Agda.Syntax.Common.Pretty.Pretty (Agda.TypeChecking.Monad.Base.IPFace' c)

module Agda.Mimer.Options
type MilliSeconds = Integer
data HintMode
Unqualified :: HintMode
AllModules :: HintMode
Module :: HintMode
NoHints :: HintMode
data Options
Options :: MilliSeconds -> HintMode -> Int -> Bool -> [QName] -> Options
[optTimeout] :: Options -> MilliSeconds
[optHintMode] :: Options -> HintMode

-- | Skip the first this many solutions
[optSkip] :: Options -> Int

-- | List solutions instead of filling the hole
[optList] :: Options -> Bool
[optExplicitHints] :: Options -> [QName]
parseOptions :: InteractionId -> Range -> String -> TCM Options
parseTime :: String -> Int
hintExprToQName :: Expr -> Maybe QName
firstOr :: a -> [a] -> a
data Token
T :: String -> Token
M :: Token
U :: Token
C :: Token
L :: Token
S :: String -> Token
H :: String -> Token
readTokens :: [String] -> [Token]
instance GHC.Show.Show Agda.Mimer.Options.HintMode
instance GHC.Classes.Eq Agda.Mimer.Options.HintMode
instance GHC.Show.Show Agda.Mimer.Options.Options
instance GHC.Show.Show Agda.Mimer.Options.Token
instance GHC.Classes.Eq Agda.Mimer.Options.Token
instance Agda.Syntax.Common.Pretty.Pretty Agda.Mimer.Options.HintMode

module Agda.Mimer.Mimer
data MimerResult

-- | Returns <a>String</a> rather than <a>Expr</a> because the give action
--   expects a string.
MimerExpr :: String -> MimerResult
MimerClauses :: QName -> [Clause] -> MimerResult
MimerList :: [(Int, String)] -> MimerResult
MimerNoResult :: MimerResult
mimer :: MonadTCM tcm => Rewrite -> InteractionId -> Range -> String -> tcm MimerResult
instance GHC.Generics.Generic Agda.Mimer.Mimer.MimerResult
instance GHC.Generics.Generic Agda.Mimer.Mimer.Goal
instance GHC.Generics.Generic Agda.Mimer.Mimer.Component
instance GHC.Classes.Eq Agda.Mimer.Mimer.Component
instance GHC.Generics.Generic Agda.Mimer.Mimer.BaseComponents
instance GHC.Generics.Generic Agda.Mimer.Mimer.SearchBranch
instance GHC.Generics.Generic Agda.Mimer.Mimer.SearchStepResult
instance GHC.Generics.Generic Agda.Mimer.Mimer.MimerStats
instance GHC.Classes.Eq Agda.Mimer.Mimer.MimerStats
instance GHC.Show.Show Agda.Mimer.Mimer.MimerStats
instance Agda.Syntax.Common.Pretty.Pretty Agda.Mimer.Mimer.SearchOptions
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Mimer.Mimer.SearchOptions
instance Control.DeepSeq.NFData Agda.Mimer.Mimer.MimerStats
instance Agda.Syntax.Common.Pretty.Pretty Agda.Mimer.Mimer.Costs
instance Control.DeepSeq.NFData Agda.Mimer.Mimer.SearchStepResult
instance Control.DeepSeq.NFData Agda.Mimer.Mimer.SearchBranch
instance GHC.Classes.Eq Agda.Mimer.Mimer.SearchBranch
instance GHC.Classes.Ord Agda.Mimer.Mimer.SearchBranch
instance Agda.Syntax.Common.Pretty.Pretty Agda.Mimer.Mimer.SearchBranch
instance Control.DeepSeq.NFData Agda.Mimer.Mimer.BaseComponents
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Mimer.Mimer.BaseComponents
instance Agda.Syntax.Common.Pretty.Pretty Agda.Mimer.Mimer.BaseComponents
instance Control.DeepSeq.NFData Agda.Mimer.Mimer.Component
instance GHC.Classes.Ord Agda.Mimer.Mimer.Component
instance Agda.Syntax.Common.Pretty.Pretty Agda.Mimer.Mimer.Component
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Mimer.Mimer.Component
instance Control.DeepSeq.NFData Agda.Mimer.Mimer.Goal
instance GHC.Classes.Eq Agda.Mimer.Mimer.Goal
instance Agda.Syntax.Common.Pretty.Pretty Agda.Mimer.Mimer.Goal
instance Control.DeepSeq.NFData Agda.Mimer.Mimer.MimerResult
instance Agda.TypeChecking.Pretty.PrettyTCM Agda.Mimer.Mimer.MimerResult

module Agda.Interaction.SearchAbout
findMentions :: Rewrite -> Range -> String -> ScopeM [(Name, Type)]


-- | This module deals with finding imported modules and loading their
--   interface files.
module Agda.Interaction.Imports

-- | Is the aim to type-check the top-level module, or only to scope-check
--   it?
data Mode
pattern ScopeCheck :: () => Mode
pattern TypeCheck :: () => Mode

-- | The result and associated parameters of a type-checked file, when
--   invoked directly via interaction or a backend. Note that the
--   constructor is not exported.
data CheckResult

-- | Flattened unidirectional pattern for <a>CheckResult</a> for
--   destructuring inside the <a>ModuleInfo</a> field.
pattern CheckResult :: Interface -> [TCWarning] -> ModuleCheckMode -> Source -> CheckResult
crModuleInfo :: CheckResult -> ModuleInfo
crInterface :: CheckResult -> Interface
crWarnings :: CheckResult -> [TCWarning]
crMode :: CheckResult -> ModuleCheckMode
crSource :: CheckResult -> Source

-- | The decorated source code.
data Source
Source :: Text -> FileType -> SourceFile -> Module -> TopLevelModuleName -> [AgdaLibFile] -> !Attributes -> Source

-- | Source code.
[srcText] :: Source -> Text

-- | Source file type
[srcFileType] :: Source -> FileType

-- | Source location at the time of its parsing
[srcOrigin] :: Source -> SourceFile

-- | The parsed module.
[srcModule] :: Source -> Module

-- | The top-level module name.
[srcModuleName] :: Source -> TopLevelModuleName

-- | The .agda-lib file(s) of the project this file belongs to.
[srcProjectLibs] :: Source -> [AgdaLibFile]

-- | Every encountered attribute.
[srcAttributes] :: Source -> !Attributes

-- | Scope checks the given module. A proper version of the module name
--   (with correct definition sites) is returned.
scopeCheckImport :: TopLevelModuleName -> ModuleName -> TCM (ModuleName, Map ModuleName Scope)

-- | Parses a source file and prepares the <a>Source</a> record.
parseSource :: SourceFile -> TCM Source

-- | Type checks the main file of the interaction. This could be the file
--   loaded in the interacting editor (emacs), or the file passed on the
--   command line.
--   
--   First, the primitive modules are imported. Then, <tt>getInterface</tt>
--   is called to do the main work.
--   
--   If the <a>Mode</a> is <a>ScopeCheck</a>, then type-checking is not
--   performed, only scope-checking. (This may include type-checking of
--   imported modules.) In this case the generated, partial interface is
--   not stored in the state (<a>stDecodedModules</a>). Note, however, that
--   if the file has already been type-checked, then a complete interface
--   is returned.
typeCheckMain :: Mode -> Source -> TCM CheckResult

-- | Read interface file corresponding to a module.
readInterface :: InterfaceFile -> TCM (Maybe Interface)
instance GHC.Show.Show Agda.Interaction.Imports.Mode
instance GHC.Classes.Eq Agda.Interaction.Imports.Mode
instance GHC.Show.Show Agda.Interaction.Imports.MainInterface
instance GHC.Classes.Eq Agda.Interaction.Imports.MainInterface

module Agda.Interaction.CommandLine
runInteractionLoop :: Maybe AbsolutePath -> TCM () -> (AbsolutePath -> TCM CheckResult) -> TCM ()
instance Control.Monad.State.Class.MonadState Agda.Interaction.CommandLine.ReplState Agda.Interaction.CommandLine.ReplM
instance Control.Monad.Reader.Class.MonadReader Agda.Interaction.CommandLine.ReplEnv Agda.Interaction.CommandLine.ReplM
instance Control.Monad.Error.Class.MonadError Agda.TypeChecking.Monad.Base.TCErr Agda.Interaction.CommandLine.ReplM
instance Agda.TypeChecking.Monad.Base.MonadTCM Agda.Interaction.CommandLine.ReplM
instance Agda.TypeChecking.Monad.Base.MonadTCState Agda.Interaction.CommandLine.ReplM
instance Agda.TypeChecking.Monad.Base.ReadTCState Agda.Interaction.CommandLine.ReplM
instance Agda.TypeChecking.Monad.Base.MonadTCEnv Agda.Interaction.CommandLine.ReplM
instance Agda.Interaction.Options.HasOptions.HasOptions Agda.Interaction.CommandLine.ReplM
instance Control.Monad.IO.Class.MonadIO Agda.Interaction.CommandLine.ReplM
instance GHC.Base.Monad Agda.Interaction.CommandLine.ReplM
instance GHC.Base.Applicative Agda.Interaction.CommandLine.ReplM
instance GHC.Base.Functor Agda.Interaction.CommandLine.ReplM

module Agda.Compiler.Common
doCompile :: Monoid r => (IsMain -> Interface -> TCM r) -> IsMain -> Interface -> TCM r
repl :: [String] -> String -> String
topLevelModuleName :: ReadTCState m => ModuleName -> m TopLevelModuleName
curIF :: ReadTCState m => m Interface
doCompile' :: Monoid r => (IsMain -> Interface -> TCM r) -> IsMain -> Interface -> StateT (Set ModuleName) TCM r
setInterface :: Interface -> TCM ()
curMName :: ReadTCState m => m TopLevelModuleName
curDefs :: ReadTCState m => m Definitions
sortDefs :: Definitions -> [(QName, Definition)]
compileDir :: HasOptions m => m FilePath

-- | Sets up the compilation environment.
inCompilerEnv :: CheckResult -> TCM a -> TCM a
data IsMain
IsMain :: IsMain
NotMain :: IsMain

module Agda.Compiler.MAlonzo.Misc
data HsModuleEnv
HsModuleEnv :: TopLevelModuleName -> Bool -> HsModuleEnv

-- | The name of the Agda module
[mazModuleName] :: HsModuleEnv -> TopLevelModuleName

-- | Whether this is the compilation root and therefore should have the
--   <tt>main</tt> function. This corresponds to the <tt>IsMain</tt> flag
--   provided to the backend, not necessarily whether the GHC module has a
--   <tt>main</tt> function defined.
[mazIsMainModule] :: HsModuleEnv -> Bool

-- | The options derived from <a>GHCFlags</a> and other shared options.
data GHCOptions
GHCOptions :: Bool -> FilePath -> [String] -> FilePath -> Bool -> Bool -> GHCOptions
[optGhcCallGhc] :: GHCOptions -> Bool

-- | Use the compiler at PATH instead of "ghc"
[optGhcBin] :: GHCOptions -> FilePath
[optGhcFlags] :: GHCOptions -> [String]
[optGhcCompileDir] :: GHCOptions -> FilePath

-- | Make inductive constructors strict?
[optGhcStrictData] :: GHCOptions -> Bool

-- | Make functions strict?
[optGhcStrict] :: GHCOptions -> Bool

-- | A static part of the GHC backend's environment that does not change
--   from module to module.
data GHCEnv
GHCEnv :: GHCOptions -> Maybe QName -> (QName -> Bool) -> Maybe Int -> Maybe Int -> GHCEnv
[ghcEnvOpts] :: GHCEnv -> GHCOptions
[ghcEnvBool, ghcEnvTrue, ghcEnvFalse, ghcEnvMaybe, ghcEnvNothing, ghcEnvJust, ghcEnvList, ghcEnvNil, ghcEnvCons, ghcEnvNat, ghcEnvInteger, ghcEnvWord64, ghcEnvInf, ghcEnvSharp, ghcEnvFlat, ghcEnvInterval, ghcEnvIZero, ghcEnvIOne, ghcEnvIsOne, ghcEnvItIsOne, ghcEnvIsOne1, ghcEnvIsOne2, ghcEnvIsOneEmpty, ghcEnvPathP, ghcEnvSub, ghcEnvSubIn, ghcEnvId, ghcEnvConId] :: GHCEnv -> Maybe QName
[ghcEnvIsTCBuiltin] :: GHCEnv -> QName -> Bool
[ghcEnvListArity] :: GHCEnv -> Maybe Int
[ghcEnvMaybeArity] :: GHCEnv -> Maybe Int

-- | Module compilation environment, bundling the overall backend session
--   options along with the module's basic readable properties.
data GHCModuleEnv
GHCModuleEnv :: GHCEnv -> HsModuleEnv -> GHCModuleEnv
[ghcModEnv] :: GHCModuleEnv -> GHCEnv
[ghcModHsModuleEnv] :: GHCModuleEnv -> HsModuleEnv

-- | Monads that can produce a <a>GHCModuleEnv</a>.
class Monad m => ReadGHCModuleEnv m
askGHCModuleEnv :: ReadGHCModuleEnv m => m GHCModuleEnv
askGHCModuleEnv :: (ReadGHCModuleEnv m, MonadTrans t, Monad n, m ~ t n, ReadGHCModuleEnv n) => m GHCModuleEnv
askHsModuleEnv :: ReadGHCModuleEnv m => m HsModuleEnv
askGHCEnv :: ReadGHCModuleEnv m => m GHCEnv
newtype HsCompileState
HsCompileState :: Set TopLevelModuleName -> HsCompileState
[mazAccumlatedImports] :: HsCompileState -> Set TopLevelModuleName

-- | Transformer adding read-only module info and a writable set of
--   imported modules
type HsCompileT m = ReaderT GHCModuleEnv (StateT HsCompileState m)

-- | The default compilation monad is the entire TCM (☹️) enriched with our
--   state and module info
type HsCompileM = HsCompileT TCM
runHsCompileT' :: HsCompileT m a -> GHCModuleEnv -> HsCompileState -> m (a, HsCompileState)
runHsCompileT :: HsCompileT m a -> GHCModuleEnv -> m (a, HsCompileState)

-- | Whether the current module is expected to have the <tt>main</tt>
--   function. This corresponds to the <tt>IsMain</tt> flag provided to the
--   backend, not necessarily whether the GHC module actually has a
--   <tt>main</tt> function defined.
curIsMainModule :: ReadGHCModuleEnv m => m Bool

-- | This is the same value as <tt>curMName</tt>, but does not rely on the
--   TCM's state. (<tt>curMName</tt> and co. should be removed, but the
--   current <tt>Backend</tt> interface is not sufficient yet to allow
--   that)
curAgdaMod :: ReadGHCModuleEnv m => m TopLevelModuleName

-- | Get the Haskell module name of the currently-focused Agda module
curHsMod :: ReadGHCModuleEnv m => m ModuleName

-- | There are two kinds of functions: those definitely without unused
--   arguments, and those that might have unused arguments.
data FunctionKind
NoUnused :: FunctionKind
PossiblyUnused :: FunctionKind

-- | Different kinds of variables: those starting with <tt>a</tt>, those
--   starting with <tt>v</tt>, and those starting with <tt>x</tt>.
data VariableKind
A :: VariableKind
V :: VariableKind
X :: VariableKind

-- | Different kinds of names.
data NameKind

-- | Types.
TypeK :: NameKind

-- | Constructors.
ConK :: NameKind

-- | Variables.
VarK :: VariableKind -> NameKind

-- | Used for coverage checking.
CoverK :: NameKind

-- | Used for constructor type checking.
CheckK :: NameKind

-- | Other functions.
FunK :: FunctionKind -> NameKind

-- | Turns strings into valid Haskell identifiers.
--   
--   In order to avoid clashes with names of regular Haskell definitions
--   (those not generated from Agda definitions), make sure that the
--   Haskell names are always used qualified, with the exception of names
--   from the prelude.
encodeString :: NameKind -> String -> String
ihname :: VariableKind -> Nat -> Name
unqhname :: NameKind -> QName -> Name
tlmodOf :: ReadTCState m => ModuleName -> m ModuleName
xqual :: QName -> Name -> HsCompileM QName
xhqn :: NameKind -> QName -> HsCompileM QName
hsName :: String -> QName
conhqn :: QName -> HsCompileM QName
bltQual :: BuiltinId -> String -> HsCompileM QName
dname :: QName -> Name

-- | Name for definition stripped of unused arguments
duname :: QName -> Name
hsPrimOp :: String -> QOp
hsPrimOpApp :: String -> Exp -> Exp -> Exp
hsInt :: Integer -> Exp
hsTypedInt :: Integral a => a -> Exp
hsTypedDouble :: Real a => a -> Exp
hsLet :: Name -> Exp -> Exp -> Exp
hsVarUQ :: Name -> Exp
hsAppView :: Exp -> [Exp]
hsOpToExp :: QOp -> Exp
hsLambda :: [Pat] -> Exp -> Exp
hsMapAlt :: (Exp -> Exp) -> Alt -> Alt
hsMapRHS :: (Exp -> Exp) -> Rhs -> Rhs
mazstr :: String
mazName :: Name
mazMod' :: String -> ModuleName
mazMod :: TopLevelModuleName -> ModuleName
mazCoerceName :: String
mazErasedName :: String
mazAnyTypeName :: String
mazCoerce :: Exp
mazUnreachableError :: Exp
rtmUnreachableError :: Exp
mazHole :: Exp
rtmHole :: String -> Exp
mazAnyType :: Type
mazRTE :: ModuleName
mazRTEFloat :: ModuleName
rtmQual :: String -> QName
rtmVar :: String -> Exp
rtmError :: Text -> Exp
unsafeCoerceMod :: ModuleName
fakeD :: Name -> String -> Decl
fakeDS :: String -> String -> Decl
fakeDQ :: QName -> String -> Decl
fakeType :: String -> Type
fakeExp :: String -> Exp
fakeDecl :: String -> Decl
emptyBinds :: Maybe Binds

-- | Can the character be used in a Haskell module name part
--   (<tt>conid</tt>)? This function is more restrictive than what the
--   Haskell report allows.
isModChar :: Char -> Bool
instance GHC.Base.Monoid Agda.Compiler.MAlonzo.Misc.HsCompileState
instance GHC.Base.Semigroup Agda.Compiler.MAlonzo.Misc.HsCompileState
instance GHC.Classes.Eq Agda.Compiler.MAlonzo.Misc.HsCompileState
instance GHC.Base.Monad m => Agda.Compiler.MAlonzo.Misc.ReadGHCModuleEnv (Control.Monad.Trans.Reader.ReaderT Agda.Compiler.MAlonzo.Misc.GHCModuleEnv m)
instance Agda.Compiler.MAlonzo.Misc.ReadGHCModuleEnv m => Agda.Compiler.MAlonzo.Misc.ReadGHCModuleEnv (Control.Monad.Trans.Except.ExceptT e m)
instance Agda.Compiler.MAlonzo.Misc.ReadGHCModuleEnv m => Agda.Compiler.MAlonzo.Misc.ReadGHCModuleEnv (Control.Monad.Trans.Identity.IdentityT m)
instance Agda.Compiler.MAlonzo.Misc.ReadGHCModuleEnv m => Agda.Compiler.MAlonzo.Misc.ReadGHCModuleEnv (Control.Monad.Trans.Maybe.MaybeT m)
instance Agda.Compiler.MAlonzo.Misc.ReadGHCModuleEnv m => Agda.Compiler.MAlonzo.Misc.ReadGHCModuleEnv (Control.Monad.Trans.State.Lazy.StateT s m)

module Agda.Compiler.MAlonzo.Primitives
newtype MainFunctionDef
MainFunctionDef :: Definition -> MainFunctionDef
data CheckedMainFunctionDef
CheckedMainFunctionDef :: MainFunctionDef -> Decl -> CheckedMainFunctionDef
[checkedMainDef] :: CheckedMainFunctionDef -> MainFunctionDef
[checkedMainDecl] :: CheckedMainFunctionDef -> Decl
asMainFunctionDef :: Definition -> Maybe MainFunctionDef
mainFunctionDefs :: Interface -> [MainFunctionDef]

-- | Check that the main function has type IO a, for some a.
checkTypeOfMain :: Definition -> HsCompileM (Maybe CheckedMainFunctionDef)
checkTypeOfMain' :: MainFunctionDef -> TCM CheckedMainFunctionDef
treelessPrimName :: TPrim -> String

-- | Haskell modules to be imported for BUILT-INs
importsForPrim :: BuiltinThings PrimFun -> [Definition] -> [ModuleName]
xForPrim :: Map SomeBuiltin a -> BuiltinThings PrimFun -> [Definition] -> [a]

-- | Definition bodies for primitive functions
primBody :: MonadTCError m => PrimitiveId -> m Exp
noCheckCover :: (HasBuiltins m, MonadReduce m) => QName -> m Bool

module Agda.Compiler.MAlonzo.Pragmas
type HaskellCode = String
type HaskellType = String

-- | GHC backend translation pragmas.
data HaskellPragma
HsDefn :: Range -> HaskellCode -> HaskellPragma
HsType :: Range -> HaskellType -> HaskellPragma

-- | @COMPILE GHC X = data D (c₁ | ... | cₙ)
HsData :: Range -> HaskellType -> [HaskellCode] -> HaskellPragma

-- | <pre>
--   COMPILE GHC x as f
--   </pre>
HsExport :: Range -> HaskellCode -> HaskellPragma
parsePragma :: CompilerPragma -> Either String HaskellPragma
parseHaskellPragma :: (MonadTCError m, MonadTrace m) => CompilerPragma -> m HaskellPragma
getHaskellPragma :: QName -> TCM (Maybe HaskellPragma)
sanityCheckPragma :: (HasBuiltins m, MonadTCError m, MonadReduce m) => Definition -> Maybe HaskellPragma -> m ()
getHaskellConstructor :: QName -> HsCompileM (Maybe HaskellCode)

-- | Get content of <tt>FOREIGN GHC</tt> pragmas, sorted by
--   <a>KindOfForeignCode</a>: file header pragmas, import statements,
--   rest.
foreignHaskell :: Interface -> ([String], [String], [String])

-- | Classify <tt>FOREIGN</tt> Haskell code.
data KindOfForeignCode

-- | A pragma that must appear before the module header.
ForeignFileHeaderPragma :: KindOfForeignCode

-- | An import statement. Must appear right after the module header.
ForeignImport :: KindOfForeignCode

-- | The rest. To appear after the import statements.
ForeignOther :: KindOfForeignCode

-- | Classify a <tt>FOREIGN GHC</tt> declaration.
classifyForeign :: String -> KindOfForeignCode

-- | Classify a Haskell pragma into whether it is a file header pragma or
--   not.
classifyPragma :: String -> KindOfForeignCode

-- | Partition a list by <a>KindOfForeignCode</a> attribute.
partitionByKindOfForeignCode :: (a -> KindOfForeignCode) -> [a] -> ([a], [a], [a])
instance GHC.Classes.Eq Agda.Compiler.MAlonzo.Pragmas.HaskellPragma
instance GHC.Show.Show Agda.Compiler.MAlonzo.Pragmas.HaskellPragma
instance Agda.Syntax.Position.HasRange Agda.Compiler.MAlonzo.Pragmas.HaskellPragma
instance Agda.Syntax.Common.Pretty.Pretty Agda.Compiler.MAlonzo.Pragmas.HaskellPragma

module Agda.Compiler.MAlonzo.Encode

-- | Haskell module names have to satisfy the Haskell (including the
--   hierarchical module namespace extension) lexical syntax:
--   
--   <pre>
--   modid -&gt; [modid.] large {small | large | digit | ' }
--   </pre>
--   
--   <a>encodeModuleName</a> is an injective function into the set of
--   module names defined by <tt>modid</tt>. The function preserves
--   <tt>.</tt>s, and it also preserves module names whose first name part
--   is not <a>mazstr</a>.
--   
--   Precondition: The input must not start or end with <tt>.</tt>, and no
--   two <tt>.</tt>s may be adjacent.
encodeModuleName :: ModuleName -> ModuleName

module Agda.Compiler.MAlonzo.Pretty
prettyPrint :: Pretty a => a -> String
prettyWhere :: Maybe Binds -> Doc -> Doc
prettyRhs :: String -> Rhs -> Doc
prettyGuardedRhs :: String -> GuardedRhs -> Doc
isOperator :: QName -> Bool
prettyQName :: QName -> Doc
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.Module
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.ModulePragma
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.ImportDecl
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.ImportSpec
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.Decl
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.ConDecl
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.Strictness
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.Match
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.Pat
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.Binds
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.DataOrNew
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.TyVarBind
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.Type
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.Stmt
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.Literal
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.Exp
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.Alt
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.ModuleName
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.QName
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.Name
instance Agda.Syntax.Common.Pretty.Pretty Agda.Utils.Haskell.Syntax.QOp


-- | Translating Agda types to Haskell types. Used to ensure that imported
--   Haskell functions have the right type.
module Agda.Compiler.MAlonzo.HaskellTypes
haskellType :: QName -> HsCompileM Type
checkConstructorCount :: QName -> [QName] -> [HaskellCode] -> TCM ()
hsTelApproximation :: Type -> HsCompileM ([Type], Type)
hsTelApproximation' :: PolyApprox -> Type -> HsCompileM ([Type], Type)
instance GHC.Classes.Eq Agda.Compiler.MAlonzo.HaskellTypes.PolyApprox


-- | Interface for compiler backend writers.
module Agda.Compiler.Backend
type Backend = Backend_boot TCM
type Backend' opts env menv mod def = Backend'_boot TCM opts env menv mod def
data Recompile menv mod
Recompile :: menv -> Recompile menv mod
Skip :: mod -> Recompile menv mod
data IsMain
IsMain :: IsMain
NotMain :: IsMain

-- | <tt>f :: Flag opts</tt> is an action on the option record that results
--   from parsing an option. <tt>f opts</tt> produces either an error
--   message or an updated options record
type Flag opts = opts -> OptM opts
toTreeless :: EvaluationStrategy -> QName -> TCM (Maybe TTerm)
data Constraint
ValueCmp :: Comparison -> CompareAs -> Term -> Term -> Constraint
ValueCmpOnFace :: Comparison -> Term -> Type -> Term -> Term -> Constraint
ElimCmp :: [Polarity] -> [IsForced] -> Type -> Term -> [Elim] -> [Elim] -> Constraint
SortCmp :: Comparison -> Sort -> Sort -> Constraint
LevelCmp :: Comparison -> Level -> Level -> Constraint
HasBiggerSort :: Sort -> Constraint
HasPTSRule :: Dom Type -> Abs Sort -> Constraint

-- | Check that the sort <a>Term</a> of data type <a>QName</a> admits
--   data/record types. E.g., sorts <tt>IUniv</tt>, <tt>SizeUniv</tt> etc.
--   do not admit such constructions. See <a>checkDataSort</a>.
CheckDataSort :: QName -> Sort -> Constraint
CheckMetaInst :: MetaId -> Constraint
CheckType :: Type -> Constraint

-- | Meta created for a term blocked by a postponed type checking problem
--   or unsolved constraints. The <a>MetaInstantiation</a> for the meta
--   (when unsolved) is either <a>BlockedConst</a> or
--   <a>PostponedTypeCheckingProblem</a>.
UnBlock :: MetaId -> Constraint

-- | The range is the one of the absurd pattern.
IsEmpty :: Range -> Type -> Constraint

-- | Check that the <a>Term</a> is either not a SIZELT or a non-empty
--   SIZELT.
CheckSizeLtSat :: Term -> Constraint

-- | the first argument is the instance argument and the second one is the
--   list of candidates (or Nothing if we haven’t determined the list of
--   candidates yet)
FindInstance :: MetaId -> Maybe [Candidate] -> Constraint

-- | Resolve the head symbol of the type that the given instance targets
ResolveInstanceHead :: QName -> Constraint

-- | Last argument is the error causing us to postpone.
CheckFunDef :: DefInfo -> QName -> [Clause] -> TCErr -> Constraint

-- | First argument is computation and the others are hole and goal type
UnquoteTactic :: Term -> Term -> Type -> Constraint

-- | <tt>CheckLockedVars t ty lk lk_ty</tt> with <tt>t : ty</tt>, <tt>lk :
--   lk_ty</tt> and <tt>t lk</tt> well-typed.
CheckLockedVars :: Term -> Type -> Arg Term -> Type -> Constraint

-- | Is the term usable at the given modality? This check should run if the
--   <tt>Sort</tt> is <tt>Nothing</tt> or <tt>isFibrant</tt>.
UsableAtModality :: WhyCheckModality -> Maybe Sort -> Modality -> Term -> Constraint
data TypeError
InternalError :: String -> TypeError
NotImplemented :: String -> TypeError
NotSupported :: String -> TypeError
CompilationError :: String -> TypeError
PropMustBeSingleton :: TypeError
DataMustEndInSort :: Term -> TypeError

-- | The target of a constructor isn't an application of its datatype. The
--   <a>Type</a> records what it does target.
ShouldEndInApplicationOfTheDatatype :: Type -> TypeError

-- | The target of a constructor isn't its datatype applied to something
--   that isn't the parameters. First term is the correct target and the
--   second term is the actual target.
ShouldBeAppliedToTheDatatypeParameters :: Term -> Term -> TypeError

-- | Expected a type to be an application of a particular datatype.
ShouldBeApplicationOf :: Type -> QName -> TypeError

-- | constructor, datatype
ConstructorPatternInWrongDatatype :: QName -> QName -> TypeError

-- | Datatype, constructors.
CantResolveOverloadedConstructorsTargetingSameDatatype :: QName -> List1 QName -> TypeError

-- | constructor, type
DoesNotConstructAnElementOf :: QName -> Type -> TypeError

-- | The left hand side of a function definition has a hidden argument
--   where a non-hidden was expected.
WrongHidingInLHS :: TypeError

-- | Expected a non-hidden function and found a hidden lambda.
WrongHidingInLambda :: Type -> TypeError

-- | A function is applied to a hidden argument where a non-hidden was
--   expected.
WrongHidingInApplication :: Type -> TypeError
WrongHidingInProjection :: QName -> TypeError
IllegalHidingInPostfixProjection :: NamedArg Expr -> TypeError

-- | A function is applied to a hidden named argument it does not have. The
--   list contains names of possible hidden arguments at this point.
WrongNamedArgument :: NamedArg Expr -> [NamedName] -> TypeError

-- | Wrong user-given relevance annotation in lambda.
WrongIrrelevanceInLambda :: TypeError

-- | Wrong user-given quantity annotation in lambda.
WrongQuantityInLambda :: TypeError

-- | Wrong user-given cohesion annotation in lambda.
WrongCohesionInLambda :: TypeError

-- | The given quantity does not correspond to the expected quantity.
QuantityMismatch :: Quantity -> Quantity -> TypeError

-- | The given hiding does not correspond to the expected hiding.
HidingMismatch :: Hiding -> Hiding -> TypeError

-- | The given relevance does not correspond to the expected relevane.
RelevanceMismatch :: Relevance -> Relevance -> TypeError
UninstantiatedDotPattern :: Expr -> TypeError
ForcedConstructorNotInstantiated :: Pattern -> TypeError
IllformedProjectionPatternAbstract :: Pattern -> TypeError
IllformedProjectionPatternConcrete :: Pattern -> TypeError
CannotEliminateWithPattern :: Maybe Blocker -> NamedArg Pattern -> Type -> TypeError
CannotEliminateWithProjection :: Arg Type -> Bool -> QName -> TypeError
WrongNumberOfConstructorArguments :: QName -> Nat -> Nat -> TypeError
ShouldBeEmpty :: Type -> [DeBruijnPattern] -> TypeError

-- | The given type should have been a sort.
ShouldBeASort :: Type -> TypeError

-- | The given type should have been a pi.
ShouldBePi :: Type -> TypeError
ShouldBePath :: Type -> TypeError
ShouldBeRecordType :: Type -> TypeError
ShouldBeRecordPattern :: DeBruijnPattern -> TypeError
NotAProjectionPattern :: NamedArg Pattern -> TypeError
NotAProperTerm :: TypeError

-- | This sort is not a type expression.
InvalidTypeSort :: Sort -> TypeError

-- | This term is not a type expression.
InvalidType :: Term -> TypeError
SplitOnCoinductive :: TypeError
SplitOnIrrelevant :: Dom Type -> TypeError
SplitOnUnusableCohesion :: Dom Type -> TypeError
SplitOnNonVariable :: Term -> Type -> TypeError
SplitOnNonEtaRecord :: QName -> TypeError
SplitOnAbstract :: QName -> TypeError
SplitOnUnchecked :: QName -> TypeError
SplitOnPartial :: Dom Type -> TypeError
SplitInProp :: DataOrRecordE -> TypeError
DefinitionIsIrrelevant :: QName -> TypeError
DefinitionIsErased :: QName -> TypeError
ProjectionIsIrrelevant :: QName -> TypeError
VariableIsIrrelevant :: Name -> TypeError
VariableIsErased :: Name -> TypeError
VariableIsOfUnusableCohesion :: Name -> Cohesion -> TypeError
UnequalLevel :: Comparison -> Level -> Level -> TypeError
UnequalTerms :: Comparison -> Term -> Term -> CompareAs -> TypeError
UnequalTypes :: Comparison -> Type -> Type -> TypeError

-- | The two function types have different relevance.
UnequalRelevance :: Comparison -> Term -> Term -> TypeError

-- | The two function types have different relevance.
UnequalQuantity :: Comparison -> Term -> Term -> TypeError

-- | The two function types have different cohesion.
UnequalCohesion :: Comparison -> Term -> Term -> TypeError

-- | One of the function types has a finite domain (i.e. is a
--   <tt>Partia</tt>l@) and the other isonot.
UnequalFiniteness :: Comparison -> Term -> Term -> TypeError

-- | The two function types have different hiding.
UnequalHiding :: Term -> Term -> TypeError
UnequalSorts :: Sort -> Sort -> TypeError
UnequalBecauseOfUniverseConflict :: Comparison -> Term -> Term -> TypeError
NotLeqSort :: Sort -> Sort -> TypeError

-- | The arguments are the meta variable and the parameter that it wants to
--   depend on.
MetaCannotDependOn :: MetaId -> Nat -> TypeError
MetaOccursInItself :: MetaId -> TypeError
MetaIrrelevantSolution :: MetaId -> Term -> TypeError
MetaErasedSolution :: MetaId -> Term -> TypeError
GenericError :: String -> TypeError
GenericDocError :: Doc -> TypeError

-- | the meta is what we might be blocked on.
SortOfSplitVarError :: Maybe Blocker -> Doc -> TypeError
BuiltinMustBeConstructor :: BuiltinId -> Expr -> TypeError
NoSuchBuiltinName :: String -> TypeError
DuplicateBuiltinBinding :: BuiltinId -> Term -> Term -> TypeError
NoBindingForBuiltin :: BuiltinId -> TypeError
NoBindingForPrimitive :: PrimitiveId -> TypeError
NoSuchPrimitiveFunction :: String -> TypeError
DuplicatePrimitiveBinding :: PrimitiveId -> QName -> QName -> TypeError
WrongArgInfoForPrimitive :: PrimitiveId -> ArgInfo -> ArgInfo -> TypeError
ShadowedModule :: Name -> [ModuleName] -> TypeError
BuiltinInParameterisedModule :: BuiltinId -> TypeError

-- | The declaration list comes from a single <a>NiceDeclaration</a>.
IllegalDeclarationInDataDefinition :: [Declaration] -> TypeError
IllegalLetInTelescope :: TypedBinding -> TypeError
IllegalPatternInTelescope :: Binder -> TypeError
NoRHSRequiresAbsurdPattern :: [NamedArg Pattern] -> TypeError

-- | Record type, fields not supplied by user, non-fields but supplied.
TooManyFields :: QName -> [Name] -> [Name] -> TypeError
DuplicateFields :: [Name] -> TypeError
DuplicateConstructors :: [Name] -> TypeError
DuplicateOverlapPragma :: QName -> OverlapMode -> OverlapMode -> TypeError
WithOnFreeVariable :: Expr -> Term -> TypeError
UnexpectedWithPatterns :: [Pattern] -> TypeError
WithClausePatternMismatch :: Pattern -> NamedArg DeBruijnPattern -> TypeError
IllTypedPatternAfterWithAbstraction :: Pattern -> TypeError
FieldOutsideRecord :: TypeError
ModuleArityMismatch :: ModuleName -> Telescope -> [NamedArg Expr] -> TypeError
GeneralizeCyclicDependency :: TypeError
GeneralizeUnsolvedMeta :: TypeError

-- | The first term references the given list of variables, which are in
--   "the future" with respect to the given lock (and its leftmost
--   variable)
ReferencesFutureVariables :: Term -> NonEmpty Int -> Arg Term -> Int -> TypeError

-- | Arguments: later term, its type, lock term. The lock term does not
--   mention any @lock variables.
DoesNotMentionTicks :: Term -> Type -> Arg Term -> TypeError
MismatchedProjectionsError :: QName -> QName -> TypeError
AttributeKindNotEnabled :: String -> String -> String -> TypeError
InvalidProjectionParameter :: NamedArg Expr -> TypeError
TacticAttributeNotAllowed :: TypeError
CannotRewriteByNonEquation :: Type -> TypeError
MacroResultTypeMismatch :: Type -> TypeError
NamedWhereModuleInRefinedContext :: [Term] -> [String] -> TypeError
CubicalPrimitiveNotFullyApplied :: QName -> TypeError
TooManyArgumentsToLeveledSort :: QName -> TypeError
TooManyArgumentsToUnivOmega :: QName -> TypeError
ComatchingDisabledForRecord :: QName -> TypeError
BuiltinMustBeIsOne :: Term -> TypeError
IncorrectTypeForRewriteRelation :: Term -> IncorrectTypeForRewriteRelationReason -> TypeError
UnexpectedParameter :: LamBinding -> TypeError
NoParameterOfName :: ArgName -> TypeError
UnexpectedModalityAnnotationInParameter :: LamBinding -> TypeError
ExpectedBindingForParameter :: Dom Type -> Abs Type -> TypeError
UnexpectedTypeSignatureForParameter :: List1 (NamedArg Binder) -> TypeError
SortDoesNotAdmitDataDefinitions :: QName -> Sort -> TypeError
SortCannotDependOnItsIndex :: QName -> Type -> TypeError
UnusableAtModality :: WhyCheckModality -> Modality -> Term -> TypeError
SplitError :: SplitError -> TypeError
ImpossibleConstructor :: QName -> NegativeUnification -> TypeError
TooManyPolarities :: QName -> Int -> TypeError

-- | A record type inferred as recursive needs a manual declaration whether
--   it should be inductively or coinductively. Sized type errors
RecursiveRecordNeedsInductivity :: QName -> TypeError

-- | The list of constraints is given redundantly as pairs of
--   <a>ProblemConstraint</a> (original constraint) and
--   <a>HypSizeConstraint</a> (form with size assumptions in context
--   spelled out). The <a>Doc</a> is some extra reason for why solving
--   failed.
CannotSolveSizeConstraints :: List1 (ProblemConstraint, HypSizeConstraint) -> Doc -> TypeError
ContradictorySizeConstraint :: (ProblemConstraint, HypSizeConstraint) -> TypeError

-- | This type, representing a type of sizes, might be empty.
EmptyTypeOfSizes :: Term -> TypeError

-- | This term, a function type constructor, lives in <tt>SizeUniv</tt>,
--   which is not allowed. Import errors
FunctionTypeInSizeUniv :: Term -> TypeError

-- | Collected errors when processing the <tt>.agda-lib</tt> file.
LibraryError :: LibErrors -> TypeError
LocalVsImportedModuleClash :: ModuleName -> TypeError

-- | Some interaction points (holes) have not been filled by user. There
--   are not <tt>UnsolvedMetas</tt> since unification solved them. This is
--   an error, since interaction points are never filled without user
--   interaction.
SolvedButOpenHoles :: TypeError
CyclicModuleDependency :: [TopLevelModuleName] -> TypeError
FileNotFound :: TopLevelModuleName -> [AbsolutePath] -> TypeError
OverlappingProjects :: AbsolutePath -> TopLevelModuleName -> TopLevelModuleName -> TypeError
AmbiguousTopLevelModuleName :: TopLevelModuleName -> [AbsolutePath] -> TypeError

-- | Found module name, expected module name.
ModuleNameUnexpected :: TopLevelModuleName -> TopLevelModuleName -> TypeError
ModuleNameDoesntMatchFileName :: TopLevelModuleName -> [AbsolutePath] -> TypeError
ClashingFileNamesFor :: ModuleName -> [AbsolutePath] -> TypeError

-- | Module name, file from which it was loaded, file which the include
--   path says contains the module.
ModuleDefinedInOtherFile :: TopLevelModuleName -> AbsolutePath -> AbsolutePath -> TypeError

-- | The file name does not correspond to a module name. Scope errors
InvalidFileName :: AbsolutePath -> InvalidFileNameReason -> TypeError
BothWithAndRHS :: TypeError
AbstractConstructorNotInScope :: QName -> TypeError
NotInScope :: [QName] -> TypeError
NoSuchModule :: QName -> TypeError
AmbiguousName :: QName -> AmbiguousNameReason -> TypeError
AmbiguousModule :: QName -> List1 ModuleName -> TypeError
AmbiguousField :: Name -> [ModuleName] -> TypeError
AmbiguousConstructor :: QName -> [QName] -> TypeError
ClashingDefinition :: QName -> QName -> Maybe NiceDeclaration -> TypeError
ClashingModule :: ModuleName -> ModuleName -> TypeError
ClashingImport :: Name -> QName -> TypeError
ClashingModuleImport :: Name -> ModuleName -> TypeError

-- | The given data/record definition rests in a different module than its
--   signature.
DefinitionInDifferentModule :: QName -> TypeError
DuplicateImports :: QName -> [ImportedName] -> TypeError
InvalidPattern :: Pattern -> TypeError
RepeatedVariablesInPattern :: [Name] -> TypeError
GeneralizeNotSupportedHere :: QName -> TypeError
GeneralizedVarInLetOpenedModule :: QName -> TypeError
MultipleFixityDecls :: [(Name, [Fixity'])] -> TypeError
MultiplePolarityPragmas :: [Name] -> TypeError

-- | The expr was used in the right hand side of an implicit module
--   definition, but it wasn't of the form <tt>m Delta</tt>.
NotAModuleExpr :: Expr -> TypeError
NotAnExpression :: Expr -> TypeError
NotAValidLetBinding :: NiceDeclaration -> TypeError
NotValidBeforeField :: NiceDeclaration -> TypeError
NothingAppliedToHiddenArg :: Expr -> TypeError
NothingAppliedToInstanceArg :: Expr -> TypeError
AsPatternInPatternSynonym :: TypeError
DotPatternInPatternSynonym :: TypeError
BadArgumentsToPatternSynonym :: AmbiguousQName -> TypeError
TooFewArgumentsToPatternSynonym :: AmbiguousQName -> TypeError
CannotResolveAmbiguousPatternSynonym :: List1 (QName, PatternSynDefn) -> TypeError

-- | This variable is bound in the lhs of the pattern synonym in instance
--   position, but not on the rhs. This is forbidden because expansion of
--   pattern synonyms would not be faithful to availability of instances in
--   instance search.
IllegalInstanceVariableInPatternSynonym :: Name -> TypeError

-- | A variable to be bound in the pattern synonym resolved on the rhs as
--   name of a constructor or a pattern synonym. The resolvents are given
--   in the list.
PatternSynonymArgumentShadowsConstructorOrPatternSynonym :: LHSOrPatSyn -> Name -> List1 AbstractName -> TypeError

-- | This variable is only bound on the lhs of the pattern synonym, not on
--   the rhs.
UnusedVariableInPatternSynonym :: Name -> TypeError

-- | These variables are only bound on the rhs of the pattern synonym, not
--   on the lhs. Operator errors
UnboundVariablesInPatternSynonym :: [Name] -> TypeError
NoParseForApplication :: List2 Expr -> TypeError
AmbiguousParseForApplication :: List2 Expr -> List1 Expr -> TypeError

-- | The list contains patterns that failed to be interpreted. If it is
--   non-empty, the first entry could be printed as error hint.
NoParseForLHS :: LHSOrPatSyn -> [Pattern] -> Pattern -> TypeError

-- | Pattern and its possible interpretations.
AmbiguousParseForLHS :: LHSOrPatSyn -> Pattern -> [Pattern] -> TypeError
AmbiguousProjection :: QName -> [QName] -> TypeError
AmbiguousOverloadedProjection :: List1 QName -> Doc -> TypeError
OperatorInformation :: [NotationSection] -> TypeError -> TypeError
InstanceNoCandidate :: Type -> [(Term, TCErr)] -> TypeError
UnquoteFailed :: UnquoteError -> TypeError
DeBruijnIndexOutOfScope :: Nat -> Telescope -> [Name] -> TypeError
NeedOptionCopatterns :: TypeError
NeedOptionRewriting :: TypeError
NeedOptionProp :: TypeError
NeedOptionTwoLevel :: TypeError
NonFatalErrors :: [TCWarning] -> TypeError
InstanceSearchDepthExhausted :: Term -> Type -> Int -> TypeError
TriedToCopyConstrainedPrim :: QName -> TypeError

-- | Used for backend-specific errors. The string is the backend name.
CustomBackendError :: String -> Doc -> TypeError
data Comparison
CmpEq :: Comparison
CmpLeq :: Comparison
data ModuleInfo
ModuleInfo :: Interface -> [TCWarning] -> Bool -> ModuleCheckMode -> ModuleInfo
[miInterface] :: ModuleInfo -> Interface

-- | Warnings were encountered when the module was type checked. These
--   might include warnings not stored in the interface itself,
--   specifically unsolved interaction metas. See
--   <a>Agda.Interaction.Imports</a>
[miWarnings] :: ModuleInfo -> [TCWarning]

-- | <a>True</a> if the module is a primitive module, which should always
--   be importable.
[miPrimitive] :: ModuleInfo -> Bool

-- | The <a>ModuleCheckMode</a> used to create the <a>Interface</a>
[miMode] :: ModuleInfo -> ModuleCheckMode
data Definition
Defn :: ArgInfo -> QName -> Type -> [Polarity] -> [Occurrence] -> NumGeneralizableArgs -> [Maybe Name] -> [LocalDisplayForm] -> MutualId -> CompiledRepresentation -> Maybe InstanceInfo -> Bool -> Set QName -> Bool -> Bool -> Bool -> Blocked_ -> !Language -> Defn -> Definition

-- | Hiding should not be used.
[defArgInfo] :: Definition -> ArgInfo

-- | The canonical name, used e.g. in compilation.
[defName] :: Definition -> QName

-- | Type of the lifted definition.
[defType] :: Definition -> Type

-- | Variance information on arguments of the definition. Does not include
--   info for dropped parameters to projection(-like) functions and
--   constructors.
[defPolarity] :: Definition -> [Polarity]

-- | Positivity information on arguments of the definition. Does not
--   include info for dropped parameters to projection(-like) functions and
--   constructors.
[defArgOccurrences] :: Definition -> [Occurrence]

-- | For a generalized variable, shows how many arguments should be
--   generalised.
[defArgGeneralizable] :: Definition -> NumGeneralizableArgs

-- | Gives the name of the (bound variable) parameter for named generalized
--   parameters. This is needed to bring it into scope when type checking
--   the data/record definition corresponding to a type with generalized
--   parameters.
[defGeneralizedParams] :: Definition -> [Maybe Name]
[defDisplay] :: Definition -> [LocalDisplayForm]
[defMutual] :: Definition -> MutualId
[defCompiledRep] :: Definition -> CompiledRepresentation

-- | <tt>Just q</tt> when this definition is an instance.
[defInstance] :: Definition -> Maybe InstanceInfo

-- | Has this function been created by a module instantiation?
[defCopy] :: Definition -> Bool

-- | The set of symbols with rewrite rules that match against this symbol
[defMatchable] :: Definition -> Set QName

-- | should compilers skip this? Used for e.g. cubical's comp
[defNoCompilation] :: Definition -> Bool

-- | Should the def be treated as injective by the pattern matching
--   unifier?
[defInjective] :: Definition -> Bool

-- | Is this a function defined by copatterns?
[defCopatternLHS] :: Definition -> Bool

-- | What blocking tag to use when we cannot reduce this def? Used when
--   checking a function definition is blocked on a meta in the type.
[defBlocked] :: Definition -> Blocked_

-- | The language used for the definition.
[defLanguage] :: Definition -> !Language
[theDef] :: Definition -> Defn
data Builtin pf
Builtin :: Term -> Builtin pf
Prim :: pf -> Builtin pf

-- | <tt>BUILTIN REWRITE</tt>. We can have several rewrite relations.
BuiltinRewriteRelations :: Set QName -> Builtin pf

-- | An alternative representation of partial elements in a telescope: Γ ⊢
--   λ Δ. [φ₁ u₁, ... , φₙ uₙ] : Δ → PartialP (∨_ᵢ φᵢ) T see cubicaltt
--   paper (however we do not store the type T).
data System
System :: Telescope -> [(Face, Term)] -> System

-- | the telescope Δ, binding vars for the clauses, Γ ⊢ Δ
[systemTel] :: System -> Telescope

-- | a system [φ₁ u₁, ... , φₙ uₙ] where Γ, Δ ⊢ φᵢ and Γ, Δ, φᵢ ⊢ uᵢ
[systemClauses] :: System -> [(Face, Term)]

-- | Type checking monad.
type TCM = TCMT IO
class (Functor m, Applicative m, MonadFail m, HasOptions m, MonadDebug m, MonadTCEnv m) => HasConstInfo m

-- | Lookup the definition of a name. The result is a closed thing, all
--   free variables have been abstracted over.
getConstInfo :: HasConstInfo m => QName -> m Definition

-- | Version that reports exceptions:
getConstInfo' :: HasConstInfo m => QName -> m (Either SigError Definition)

-- | Lookup the rewrite rules with the given head symbol.
getRewriteRulesFor :: HasConstInfo m => QName -> m RewriteRules

-- | Version that reports exceptions:
getConstInfo' :: (HasConstInfo m, HasConstInfo n, MonadTrans t, m ~ t n) => QName -> m (Either SigError Definition)

-- | Lookup the rewrite rules with the given head symbol.
getRewriteRulesFor :: (HasConstInfo m, HasConstInfo n, MonadTrans t, m ~ t n) => QName -> m RewriteRules
newtype ReduceM a
ReduceM :: (ReduceEnv -> a) -> ReduceM a
[unReduceM] :: ReduceM a -> ReduceEnv -> a
class (Functor m, Applicative m, Monad m) => MonadDebug m
formatDebugMessage :: MonadDebug m => VerboseKey -> VerboseLevel -> TCM Doc -> m String
traceDebugMessage :: MonadDebug m => VerboseKey -> VerboseLevel -> String -> m a -> m a

-- | Print brackets around debug messages issued by a computation.
verboseBracket :: MonadDebug m => VerboseKey -> VerboseLevel -> String -> m a -> m a
getVerbosity :: MonadDebug m => m Verbosity
getProfileOptions :: MonadDebug m => m ProfileOptions

-- | Check whether we are currently debug printing.
isDebugPrinting :: MonadDebug m => m Bool

-- | Flag in a computation that we are currently debug printing.
nowDebugPrinting :: MonadDebug m => m a -> m a
formatDebugMessage :: (MonadDebug m, MonadTrans t, MonadDebug n, m ~ t n) => VerboseKey -> VerboseLevel -> TCM Doc -> m String
traceDebugMessage :: (MonadDebug m, MonadTransControl t, MonadDebug n, m ~ t n) => VerboseKey -> VerboseLevel -> String -> m a -> m a

-- | Print brackets around debug messages issued by a computation.
verboseBracket :: (MonadDebug m, MonadTransControl t, MonadDebug n, m ~ t n) => VerboseKey -> VerboseLevel -> String -> m a -> m a
getVerbosity :: (MonadDebug m, MonadTrans t, MonadDebug n, m ~ t n) => m Verbosity
getProfileOptions :: (MonadDebug m, MonadTrans t, MonadDebug n, m ~ t n) => m ProfileOptions

-- | Check whether we are currently debug printing.
isDebugPrinting :: (MonadDebug m, MonadTrans t, MonadDebug n, m ~ t n) => m Bool

-- | Flag in a computation that we are currently debug printing.
nowDebugPrinting :: (MonadDebug m, MonadTransControl t, MonadDebug n, m ~ t n) => m a -> m a

-- | How much highlighting should be sent to the user interface?
data HighlightingLevel
None :: HighlightingLevel
NonInteractive :: HighlightingLevel

-- | This includes both non-interactive highlighting and interactive
--   highlighting of the expression that is currently being type-checked.
Interactive :: HighlightingLevel

-- | How should highlighting be sent to the user interface?
data HighlightingMethod

-- | Via stdout.
Direct :: HighlightingMethod

-- | Both via files and via stdout.
Indirect :: HighlightingMethod

-- | Polarity for equality and subtype checking.
data Polarity

-- | monotone
Covariant :: Polarity

-- | antitone
Contravariant :: Polarity

-- | no information (mixed variance)
Invariant :: Polarity

-- | constant
Nonvariant :: Polarity

-- | A thing tagged with the context it came from. Also keeps the
--   substitution from previous checkpoints. This lets us handle the case
--   when an open thing was created in a context that we have since exited.
--   Remember which module it's from to make sure we don't get confused by
--   checkpoints from other files.
data Open a
OpenThing :: CheckpointId -> Map CheckpointId Substitution -> ModuleNameHash -> a -> Open a
[openThingCheckpoint] :: Open a -> CheckpointId
[openThingCheckpointMap] :: Open a -> Map CheckpointId Substitution
[openThingModule] :: Open a -> ModuleNameHash
[openThing] :: Open a -> a

-- | <tt>MetaInfo</tt> is cloned from one meta to the next during pruning.
data MetaInfo
MetaInfo :: Closure Range -> Modality -> RunMetaOccursCheck -> MetaNameSuggestion -> Arg DoGeneralize -> MetaInfo
[miClosRange] :: MetaInfo -> Closure Range

-- | Instantiable with irrelevant/erased solution?
[miModality] :: MetaInfo -> Modality

-- | Run the extended occurs check that goes in definitions?
[miMetaOccursCheck] :: MetaInfo -> RunMetaOccursCheck

-- | Used for printing. <tt>Just x</tt> if meta-variable comes from omitted
--   argument with name <tt>x</tt>.
[miNameSuggestion] :: MetaInfo -> MetaNameSuggestion

-- | Should this meta be generalized if unsolved? If so, at what ArgInfo?
[miGeneralizable] :: MetaInfo -> Arg DoGeneralize
type Constraints = [ProblemConstraint]

-- | Assorted warnings and errors to be displayed to the user
data WarningsAndNonFatalErrors
WarningsAndNonFatalErrors :: [TCWarning] -> [TCWarning] -> WarningsAndNonFatalErrors
[tcWarnings] :: WarningsAndNonFatalErrors -> [TCWarning]
[nonFatalErrors] :: WarningsAndNonFatalErrors -> [TCWarning]
data Signature
Sig :: Sections -> Definitions -> RewriteRuleMap -> InstanceTable -> Signature
[_sigSections] :: Signature -> Sections
[_sigDefinitions] :: Signature -> Definitions

-- | The rewrite rules defined in this file.
[_sigRewriteRules] :: Signature -> RewriteRuleMap
[_sigInstances] :: Signature -> InstanceTable

-- | A non-fatal error is an error which does not prevent us from checking
--   the document further and interacting with the user.
data Warning
NicifierIssue :: DeclarationWarning -> Warning
TerminationIssue :: [TerminationError] -> Warning

-- | `UnreachableClauses f rs` means that the clauses in <tt>f</tt> whose
--   ranges are rs are unreachable
UnreachableClauses :: QName -> [Range] -> Warning

-- | `CoverageIssue f pss` means that <tt>pss</tt> are not covered in
--   <tt>f</tt>
CoverageIssue :: QName -> [(Telescope, [NamedArg DeBruijnPattern])] -> Warning
CoverageNoExactSplit :: QName -> [Clause] -> Warning

-- | <a>Clause</a> was turned into copattern matching clause(s) by an
--   <tt>{-# INLINE constructor #-}</tt> and thus is not a definitional
--   equality any more.
InlineNoExactSplit :: QName -> Clause -> Warning
NotStrictlyPositive :: QName -> Seq OccursWhere -> Warning

-- | Checking whether constructor <a>QName</a> <a>Term</a> fits into
--   <tt>data</tt> <a>Term</a> produced <a>TCErr</a>
ConstructorDoesNotFitInData :: QName -> Sort -> Sort -> TCErr -> Warning

-- | A record type declared as both <tt>coinductive</tt> and having
--   <tt>eta-equality</tt>.
CoinductiveEtaRecord :: QName -> Warning

-- | Do not use directly with <tt>warning</tt>
UnsolvedMetaVariables :: [Range] -> Warning

-- | Do not use directly with <tt>warning</tt>
UnsolvedInteractionMetas :: [Range] -> Warning

-- | Do not use directly with <tt>warning</tt>
UnsolvedConstraints :: Constraints -> Warning

-- | Do not use directly with <tt>warning</tt>
InteractionMetaBoundaries :: [Range] -> Warning
CantGeneralizeOverSorts :: [MetaId] -> Warning
AbsurdPatternRequiresNoRHS :: [NamedArg DeBruijnPattern] -> Warning

-- | In `OldBuiltin old new`, the BUILTIN old has been replaced by new.
OldBuiltin :: BuiltinId -> BuiltinId -> Warning

-- | The builtin declares a new identifier, so it should not be in scope.
BuiltinDeclaresIdentifier :: BuiltinId -> Warning

-- | The given record directive is conflicting with a prior one in the same
--   record declaration.
DuplicateRecordDirective :: RecordDirective -> Warning

-- | If the user wrote just <tt>{-# REWRITE #-}</tt>.
EmptyRewritePragma :: Warning

-- | An empty <tt>where</tt> block is dead code.
EmptyWhere :: Warning

-- | If the user wrote something other than an unqualified name in the
--   <tt>as</tt> clause of an <tt>import</tt> statement. The <a>String</a>
--   gives optionally extra explanation.
IllformedAsClause :: String -> Warning

-- | A character literal Agda does not support, e.g. surrogate code points.
InvalidCharacterLiteral :: Char -> Warning

-- | If a <tt>renaming</tt> import directive introduces a name or module
--   name clash in the exported names of a module. (See issue #4154.)
ClashesViaRenaming :: NameOrModule -> [Name] -> Warning

-- | The 'pattern' declaration is useless in the presence of either
--   <tt>coinductive</tt> or <tt>eta-equality</tt>. Content of
--   <a>String</a> is "coinductive" or "eta", resp.
UselessPatternDeclarationForRecord :: String -> Warning

-- | Warning when pragma is useless and thus ignored. <a>Range'</a> is for
--   dead code highlighting.
UselessPragma :: Range -> Doc -> Warning

-- | If the user opens a module public before the module header. (See issue
--   #2377.)
UselessPublic :: Warning

-- | Names in <a>hiding</a> directive that don't hide anything imported by
--   a <a>using</a> directive.
UselessHiding :: [ImportedName] -> Warning
UselessInline :: QName -> Warning
WrongInstanceDeclaration :: Warning

-- | An instance was declared with an implicit argument, which means it
--   will never actually be considered by instance search.
InstanceWithExplicitArg :: QName -> Warning

-- | The type of an instance argument doesn't end in a named or variable
--   type, so it will never be considered by instance search.
InstanceNoOutputTypeName :: Doc -> Warning

-- | As InstanceWithExplicitArg, but for local bindings rather than
--   top-level instances.
InstanceArgWithExplicitArg :: Doc -> Warning

-- | The --inversion-max-depth was reached.
InversionDepthReached :: QName -> Warning

-- | A coinductive record was declared but neither --guardedness nor
--   --sized-types is enabled.
NoGuardednessFlag :: QName -> Warning
SafeFlagPostulate :: Name -> Warning

-- | Unsafe OPTIONS.
SafeFlagPragma :: [String] -> Warning
SafeFlagWithoutKFlagPrimEraseEquality :: Warning
WithoutKFlagPrimEraseEquality :: Warning

-- | `ConflictingPragmaOptions a b`: Inconsistent options `--a` and
--   `--no-b`, since `--a` implies `--b`. Ignoring `--no-b`.
ConflictingPragmaOptions :: String -> String -> Warning
OptionWarning :: OptionWarning -> Warning
ParseWarning :: ParseWarning -> Warning
LibraryWarning :: LibWarning -> Warning

-- | `DeprecationWarning old new version`: <tt>old</tt> is deprecated, use
--   <tt>new</tt> instead. This will be an error in Agda <tt>version</tt>.
DeprecationWarning :: String -> String -> String -> Warning

-- | User-defined warning (e.g. to mention that a name is deprecated)
UserWarning :: Text -> Warning

-- | Duplicate mentions of the same name in <tt>using</tt> directive(s).
DuplicateUsing :: List1 ImportedName -> Warning

-- | Fixity of modules cannot be changed via renaming (since modules have
--   no fixity).
FixityInRenamingModule :: List1 Range -> Warning

-- | Some imported names are not actually exported by the source module.
--   The second argument is the names that could be exported. The third
--   argument is the module names that could be exported.
ModuleDoesntExport :: QName -> [Name] -> [Name] -> [ImportedName] -> Warning

-- | Importing a file using an infective option into one which doesn't
InfectiveImport :: Doc -> Warning

-- | Importing a file not using a coinfective option from one which does
CoInfectiveImport :: Doc -> Warning

-- | Confluence checking incomplete because the definition of the
--   <a>QName</a> contains unsolved metavariables.
ConfluenceCheckingIncompleteBecauseOfMeta :: QName -> Warning

-- | Confluence checking with <tt>--cubical</tt> might be incomplete.
ConfluenceForCubicalNotSupported :: Warning
IllegalRewriteRule :: QName -> IllegalRewriteRuleReason -> Warning

-- | Confluence checker found critical pair and equality checking resulted
--   in a type error
RewriteNonConfluent :: Term -> Term -> Term -> Doc -> Warning

-- | Confluence checker got stuck on computing overlap between two rewrite
--   rules
RewriteMaybeNonConfluent :: Term -> Term -> [Doc] -> Warning

-- | The global confluence checker found a term <tt>u</tt> that reduces to
--   both <tt>v1</tt> and <tt>v2</tt> and there is no rule to resolve the
--   ambiguity.
RewriteAmbiguousRules :: Term -> Term -> Term -> Warning

-- | The global confluence checker found a term <tt>u</tt> that reduces to
--   <tt>v</tt>, but <tt>v</tt> does not reduce to <tt>rho(u)</tt>.
RewriteMissingRule :: Term -> Term -> Term -> Warning

-- | COMPILE directive for an erased symbol.
PragmaCompileErased :: BackendName -> QName -> Warning

-- | <tt>COMPILE GHC</tt> pragma for lists; ignored.
PragmaCompileList :: Warning

-- | <tt>COMPILE GHC</tt> pragma for <tt>MAYBE</tt>; ignored.
PragmaCompileMaybe :: Warning

-- | Compiler run on module that does not have a <tt>main</tt> function.
NoMain :: TopLevelModuleName -> Warning

-- | Out of scope error we can recover from.
NotInScopeW :: [QName] -> Warning

-- | Was not able to compute a full equivalence when splitting.
UnsupportedIndexedMatch :: Doc -> Warning

-- | The as-name in an as-pattern may not shadow a constructor
--   (<a>IsLHS</a>) or pattern synonym name (<a>IsPatSyn</a>), because this
--   can be confusing to read.
AsPatternShadowsConstructorOrPatternSynonym :: LHSOrPatSyn -> Warning

-- | A pattern variable has the name of a constructor (data constructor or
--   matchable record constructor).
PatternShadowsConstructor :: Name -> QName -> Warning

-- | Explicit use of @<tt>ω</tt> or @<tt>plenty</tt> in hard compile-time
--   mode.
PlentyInHardCompileTimeMode :: QωOrigin -> Warning
RecordFieldWarning :: RecordFieldWarning -> Warning

-- | An <tt>abstract</tt> or <tt>opaque</tt> definition lacks a type
--   signature.
MissingTypeSignatureForOpaque :: QName -> IsOpaque -> Warning
NotAffectedByOpaque :: Warning
UnfoldTransparentName :: QName -> Warning
UselessOpaque :: Warning

-- | Face constraint patterns <tt>(i = 0)</tt> must be visible arguments.
FaceConstraintCannotBeHidden :: ArgInfo -> Warning

-- | Face constraint patterns <tt>(i = 0)</tt> must be unnamed arguments.
FaceConstraintCannotBeNamed :: NamedName -> Warning

-- | `DuplicateInterfaceFiles selectedInterfaceFile ignoredInterfaceFile`
DuplicateInterfaceFiles :: AbsolutePath -> AbsolutePath -> Warning

-- | Used for backend-specific warnings. The string is the backend name.
CustomBackendWarning :: String -> Doc -> Warning

-- | Type-checking errors.
data TCErr
TypeError :: CallStack -> TCState -> Closure TypeError -> TCErr

-- | Location in the internal Agda source code where the error was raised
[tcErrLocation] :: TCErr -> CallStack

-- | The state in which the error was raised.
[tcErrState] :: TCErr -> TCState

-- | The environment in which the error as raised plus the error.
[tcErrClosErr] :: TCErr -> Closure TypeError
Exception :: Range -> Doc -> TCErr

-- | The first argument is the state in which the error was raised.
IOException :: TCState -> Range -> IOException -> TCErr

-- | The exception which is usually caught. Raised for pattern violations
--   during unification (<tt>assignV</tt>) but also in other situations
--   where we want to backtrack. Contains an unblocker to control when the
--   computation should be retried.
PatternErr :: Blocker -> TCErr
data TCWarning
TCWarning :: CallStack -> Range -> Warning -> Doc -> Bool -> TCWarning

-- | Location in the internal Agda source code location where the error
--   raised
[tcWarningLocation] :: TCWarning -> CallStack

-- | Range where the warning was raised
[tcWarningRange] :: TCWarning -> Range

-- | The warning itself
[tcWarning] :: TCWarning -> Warning

-- | The warning printed in the state and environment where it was raised
[tcWarningPrintedWarning] :: TCWarning -> Doc

-- | Should the warning be affected by caching.
[tcWarningCached] :: TCWarning -> Bool

-- | For printing, we couple a meta with its name suggestion.
data NamedMeta
NamedMeta :: MetaNameSuggestion -> MetaId -> NamedMeta
[nmSuggestion] :: NamedMeta -> MetaNameSuggestion
[nmid] :: NamedMeta -> MetaId

-- | Maps top-level module names to the corresponding source file names.
type ModuleToSource = Map TopLevelModuleName AbsolutePath
type Definitions = HashMap QName Definition

-- | Callback fuction to call when there is a response to give to the
--   interactive frontend.
--   
--   Note that the response is given in pieces and incrementally, so the
--   user can have timely response even during long computations.
--   
--   Typical <a>InteractionOutputCallback</a> functions:
--   
--   <ul>
--   <li>Convert the response into a <a>String</a> representation and print
--   it on standard output (suitable for inter-process communication).</li>
--   <li>Put the response into a mutable variable stored in the closure of
--   the <a>InteractionOutputCallback</a> function. (suitable for
--   intra-process communication).</li>
--   </ul>
type InteractionOutputCallback = Response_boot TCErr TCWarning WarningsAndNonFatalErrors -> TCM ()

-- | Datatype representing a single boundary condition: x_0 = u_0, ... ,x_n
--   = u_n ⊢ t = ?n es
data IPFace' t
IPFace' :: [(t, t)] -> t -> IPFace' t
[faceEqns] :: IPFace' t -> [(t, t)]
[faceRHS] :: IPFace' t -> t
class (Functor m, Applicative m, Monad m) => HasOptions m

-- | Returns the pragma options which are currently in effect.
pragmaOptions :: HasOptions m => m PragmaOptions

-- | Returns the command line options which are currently in effect.
commandLineOptions :: HasOptions m => m CommandLineOptions

-- | Returns the pragma options which are currently in effect.
pragmaOptions :: (HasOptions m, HasOptions n, MonadTrans t, m ~ t n) => m PragmaOptions

-- | Returns the command line options which are currently in effect.
commandLineOptions :: (HasOptions m, HasOptions n, MonadTrans t, m ~ t n) => m CommandLineOptions

-- | <tt>MonadTCEnv</tt> made into its own dedicated service class. This
--   allows us to use <a>MonadReader</a> for <a>ReaderT</a> extensions of
--   <tt>TCM</tt>.
class Monad m => MonadTCEnv m
askTC :: MonadTCEnv m => m TCEnv
localTC :: MonadTCEnv m => (TCEnv -> TCEnv) -> m a -> m a
askTC :: (MonadTCEnv m, MonadTrans t, MonadTCEnv n, t n ~ m) => m TCEnv
localTC :: (MonadTCEnv m, MonadTransControl t, MonadTCEnv n, t n ~ m) => (TCEnv -> TCEnv) -> m a -> m a

-- | Embedding a TCM computation.
class (Applicative tcm, MonadIO tcm, MonadTCEnv tcm, MonadTCState tcm, HasOptions tcm) => MonadTCM tcm
liftTCM :: MonadTCM tcm => TCM a -> tcm a
liftTCM :: (MonadTCM tcm, MonadTCM m, MonadTrans t, tcm ~ t m) => TCM a -> tcm a

-- | <tt>MonadTCState</tt> made into its own dedicated service class. This
--   allows us to use <a>MonadState</a> for <a>StateT</a> extensions of
--   <tt>TCM</tt>.
class Monad m => MonadTCState m
getTC :: MonadTCState m => m TCState
putTC :: MonadTCState m => TCState -> m ()
modifyTC :: MonadTCState m => (TCState -> TCState) -> m ()
getTC :: (MonadTCState m, MonadTrans t, MonadTCState n, t n ~ m) => m TCState
putTC :: (MonadTCState m, MonadTrans t, MonadTCState n, t n ~ m) => TCState -> m ()
modifyTC :: (MonadTCState m, MonadTrans t, MonadTCState n, t n ~ m) => (TCState -> TCState) -> m ()
class Monad m => ReadTCState m
getTCState :: ReadTCState m => m TCState
locallyTCState :: ReadTCState m => Lens' TCState a -> (a -> a) -> m b -> m b
withTCState :: ReadTCState m => (TCState -> TCState) -> m a -> m a
getTCState :: (ReadTCState m, MonadTrans t, ReadTCState n, t n ~ m) => m TCState
locallyTCState :: (ReadTCState m, MonadTransControl t, ReadTCState n, t n ~ m) => Lens' TCState a -> (a -> a) -> m b -> m b

-- | The type checking monad transformer. Adds readonly <a>TCEnv</a> and
--   mutable <a>TCState</a>.
newtype TCMT m a
TCM :: (IORef TCState -> TCEnv -> m a) -> TCMT m a
[unTCM] :: TCMT m a -> IORef TCState -> TCEnv -> m a

-- | Either a <a>BuiltinId</a> or <a>PrimitiveId</a>, used for some
--   lookups.
data SomeBuiltin
BuiltinName :: !BuiltinId -> SomeBuiltin
PrimitiveName :: !PrimitiveId -> SomeBuiltin

-- | Distinguish error message when parsing lhs or pattern synonym, resp.
data LHSOrPatSyn
IsLHS :: LHSOrPatSyn
IsPatSyn :: LHSOrPatSyn
class (Functor m, Applicative m, MonadFail m) => HasBuiltins m
getBuiltinThing :: HasBuiltins m => SomeBuiltin -> m (Maybe (Builtin PrimFun))
getBuiltinThing :: (HasBuiltins m, MonadTrans t, HasBuiltins n, t n ~ m) => SomeBuiltin -> m (Maybe (Builtin PrimFun))

-- | The <tt>Context</tt> is a stack of <a>ContextEntry</a>s.
type Context = [ContextEntry]

-- | A <tt>DisplayForm</tt> is in essence a rewrite rule <tt>q ts --&gt;
--   dt</tt> for a defined symbol (could be a constructor as well)
--   <tt>q</tt>. The right hand side is a <a>DisplayTerm</a> which is used
--   to <tt>reify</tt> to a more readable <a>Syntax</a>.
--   
--   The patterns <tt>ts</tt> are just terms, but the first
--   <tt>dfPatternVars</tt> variables are pattern variables that matches
--   any term.
data DisplayForm
Display :: Nat -> Elims -> DisplayTerm -> DisplayForm

-- | Number <tt>n</tt> of pattern variables in <a>dfPats</a>.
[dfPatternVars] :: DisplayForm -> Nat

-- | Left hand side patterns, the <tt>n</tt> first free variables are
--   pattern variables, any variables above <tt>n</tt> are fixed and only
--   match that particular variable. This happens when you have display
--   forms inside parameterised modules that match on the module
--   parameters. The <a>ArgInfo</a> is ignored in these patterns.
[dfPats] :: DisplayForm -> Elims

-- | Right hand side.
[dfRHS] :: DisplayForm -> DisplayTerm
data Call
CheckClause :: Type -> SpineClause -> Call
CheckLHS :: SpineLHS -> Call
CheckPattern :: Pattern -> Telescope -> Type -> Call
CheckPatternLinearityType :: Name -> Call
CheckPatternLinearityValue :: Name -> Call
CheckLetBinding :: LetBinding -> Call
InferExpr :: Expr -> Call
CheckExprCall :: Comparison -> Expr -> Type -> Call
CheckDotPattern :: Expr -> Term -> Call
CheckProjection :: Range -> QName -> Type -> Call
IsTypeCall :: Comparison -> Expr -> Sort -> Call
IsType_ :: Expr -> Call
InferVar :: Name -> Call
InferDef :: QName -> Call
CheckArguments :: Range -> [NamedArg Expr] -> Type -> Maybe Type -> Call
CheckMetaSolution :: Range -> MetaId -> Type -> Term -> Call
CheckTargetType :: Range -> Type -> Type -> Call
CheckDataDef :: Range -> QName -> [LamBinding] -> [Constructor] -> Call
CheckRecDef :: Range -> QName -> [LamBinding] -> [Constructor] -> Call
CheckConstructor :: QName -> Telescope -> Sort -> Constructor -> Call
CheckConArgFitsIn :: QName -> Bool -> Type -> Sort -> Call

-- | Highlight (interactively) if and only if the boolean is <a>True</a>.
CheckFunDefCall :: Range -> QName -> [Clause] -> Bool -> Call
CheckPragma :: Range -> Pragma -> Call
CheckPrimitive :: Range -> QName -> Expr -> Call
CheckIsEmpty :: Range -> Type -> Call
CheckConfluence :: QName -> QName -> Call
CheckModuleParameters :: ModuleName -> Telescope -> Call
CheckWithFunctionType :: Type -> Call
CheckSectionApplication :: Range -> Erased -> ModuleName -> ModuleApplication -> Call
CheckNamedWhere :: ModuleName -> Call

-- | Checking a clause for confluence with endpoint reductions. Always
--   <tt>φ ⊢ f vs = rhs</tt> for now, but we store the simplifications of
--   <tt>f vs[φ]</tt> and <tt>rhs[φ]</tt>.
CheckIApplyConfluence :: Range -> QName -> Term -> Term -> Term -> Type -> Call
ScopeCheckExpr :: Expr -> Call
ScopeCheckDeclaration :: NiceDeclaration -> Call
ScopeCheckLHS :: QName -> Pattern -> Call
NoHighlighting :: Call

-- | Interaction command: show module contents.
ModuleContents :: Call

-- | used by <tt>setCurrentRange</tt>
SetRange :: Range -> Call

-- | Monad service class containing methods for adding and solving
--   constraints
class (MonadTCEnv m, ReadTCState m, MonadError TCErr m, MonadBlock m, HasOptions m, MonadDebug m) => MonadConstraint m

-- | Unconditionally add the constraint.
addConstraint :: MonadConstraint m => Blocker -> Constraint -> m ()

-- | Add constraint as awake constraint.
addAwakeConstraint :: MonadConstraint m => Blocker -> Constraint -> m ()
solveConstraint :: MonadConstraint m => Constraint -> m ()

-- | Solve awake constraints matching the predicate. If the second argument
--   is True solve constraints even if already <a>isSolvingConstraints</a>.
solveSomeAwakeConstraints :: MonadConstraint m => (ProblemConstraint -> Bool) -> Bool -> m ()
wakeConstraints :: MonadConstraint m => (ProblemConstraint -> WakeUp) -> m ()
stealConstraints :: MonadConstraint m => ProblemId -> m ()
modifyAwakeConstraints :: MonadConstraint m => (Constraints -> Constraints) -> m ()
modifySleepingConstraints :: MonadConstraint m => (Constraints -> Constraints) -> m ()
data Closure a
Closure :: Signature -> TCEnv -> ScopeInfo -> Map ModuleName CheckpointId -> a -> Closure a
[clSignature] :: Closure a -> Signature
[clEnv] :: Closure a -> TCEnv
[clScope] :: Closure a -> ScopeInfo
[clModuleCheckpoints] :: Closure a -> Map ModuleName CheckpointId
[clValue] :: Closure a -> a
data RecordFieldWarning

-- | A builtin name, defined by the <tt>BUILTIN</tt> pragma.
data BuiltinId
BuiltinNat :: BuiltinId
BuiltinSuc :: BuiltinId
BuiltinZero :: BuiltinId
BuiltinNatPlus :: BuiltinId
BuiltinNatMinus :: BuiltinId
BuiltinNatTimes :: BuiltinId
BuiltinNatDivSucAux :: BuiltinId
BuiltinNatModSucAux :: BuiltinId
BuiltinNatEquals :: BuiltinId
BuiltinNatLess :: BuiltinId
BuiltinWord64 :: BuiltinId
BuiltinInteger :: BuiltinId
BuiltinIntegerPos :: BuiltinId
BuiltinIntegerNegSuc :: BuiltinId
BuiltinFloat :: BuiltinId
BuiltinChar :: BuiltinId
BuiltinString :: BuiltinId
BuiltinUnit :: BuiltinId
BuiltinUnitUnit :: BuiltinId
BuiltinSigma :: BuiltinId
BuiltinSigmaCon :: BuiltinId
BuiltinBool :: BuiltinId
BuiltinTrue :: BuiltinId
BuiltinFalse :: BuiltinId
BuiltinList :: BuiltinId
BuiltinNil :: BuiltinId
BuiltinCons :: BuiltinId
BuiltinMaybe :: BuiltinId
BuiltinNothing :: BuiltinId
BuiltinJust :: BuiltinId
BuiltinIO :: BuiltinId
BuiltinId :: BuiltinId
BuiltinReflId :: BuiltinId
BuiltinPath :: BuiltinId
BuiltinPathP :: BuiltinId
BuiltinIntervalUniv :: BuiltinId
BuiltinInterval :: BuiltinId
BuiltinIZero :: BuiltinId
BuiltinIOne :: BuiltinId
BuiltinPartial :: BuiltinId
BuiltinPartialP :: BuiltinId
BuiltinIsOne :: BuiltinId
BuiltinItIsOne :: BuiltinId
BuiltinEquiv :: BuiltinId
BuiltinEquivFun :: BuiltinId
BuiltinEquivProof :: BuiltinId
BuiltinTranspProof :: BuiltinId
BuiltinIsOne1 :: BuiltinId
BuiltinIsOne2 :: BuiltinId
BuiltinIsOneEmpty :: BuiltinId
BuiltinSub :: BuiltinId
BuiltinSubIn :: BuiltinId
BuiltinSizeUniv :: BuiltinId
BuiltinSize :: BuiltinId
BuiltinSizeLt :: BuiltinId
BuiltinSizeSuc :: BuiltinId
BuiltinSizeInf :: BuiltinId
BuiltinSizeMax :: BuiltinId
BuiltinInf :: BuiltinId
BuiltinSharp :: BuiltinId
BuiltinFlat :: BuiltinId
BuiltinEquality :: BuiltinId
BuiltinRefl :: BuiltinId
BuiltinRewrite :: BuiltinId
BuiltinLevelMax :: BuiltinId
BuiltinLevel :: BuiltinId
BuiltinLevelZero :: BuiltinId
BuiltinLevelSuc :: BuiltinId
BuiltinProp :: BuiltinId
BuiltinSet :: BuiltinId
BuiltinStrictSet :: BuiltinId
BuiltinPropOmega :: BuiltinId
BuiltinSetOmega :: BuiltinId
BuiltinSSetOmega :: BuiltinId
BuiltinLevelUniv :: BuiltinId
BuiltinFromNat :: BuiltinId
BuiltinFromNeg :: BuiltinId
BuiltinFromString :: BuiltinId
BuiltinQName :: BuiltinId
BuiltinAgdaSort :: BuiltinId
BuiltinAgdaSortSet :: BuiltinId
BuiltinAgdaSortLit :: BuiltinId
BuiltinAgdaSortProp :: BuiltinId
BuiltinAgdaSortPropLit :: BuiltinId
BuiltinAgdaSortInf :: BuiltinId
BuiltinAgdaSortUnsupported :: BuiltinId
BuiltinHiding :: BuiltinId
BuiltinHidden :: BuiltinId
BuiltinInstance :: BuiltinId
BuiltinVisible :: BuiltinId
BuiltinRelevance :: BuiltinId
BuiltinRelevant :: BuiltinId
BuiltinIrrelevant :: BuiltinId
BuiltinQuantity :: BuiltinId
BuiltinQuantity0 :: BuiltinId
BuiltinQuantityω :: BuiltinId
BuiltinModality :: BuiltinId
BuiltinModalityConstructor :: BuiltinId
BuiltinAssoc :: BuiltinId
BuiltinAssocLeft :: BuiltinId
BuiltinAssocRight :: BuiltinId
BuiltinAssocNon :: BuiltinId
BuiltinPrecedence :: BuiltinId
BuiltinPrecRelated :: BuiltinId
BuiltinPrecUnrelated :: BuiltinId
BuiltinFixity :: BuiltinId
BuiltinFixityFixity :: BuiltinId
BuiltinArg :: BuiltinId
BuiltinArgInfo :: BuiltinId
BuiltinArgArgInfo :: BuiltinId
BuiltinArgArg :: BuiltinId
BuiltinAbs :: BuiltinId
BuiltinAbsAbs :: BuiltinId
BuiltinAgdaTerm :: BuiltinId
BuiltinAgdaTermVar :: BuiltinId
BuiltinAgdaTermLam :: BuiltinId
BuiltinAgdaTermExtLam :: BuiltinId
BuiltinAgdaTermDef :: BuiltinId
BuiltinAgdaTermCon :: BuiltinId
BuiltinAgdaTermPi :: BuiltinId
BuiltinAgdaTermSort :: BuiltinId
BuiltinAgdaTermLit :: BuiltinId
BuiltinAgdaTermUnsupported :: BuiltinId
BuiltinAgdaTermMeta :: BuiltinId
BuiltinAgdaErrorPart :: BuiltinId
BuiltinAgdaErrorPartString :: BuiltinId
BuiltinAgdaErrorPartTerm :: BuiltinId
BuiltinAgdaErrorPartPatt :: BuiltinId
BuiltinAgdaErrorPartName :: BuiltinId
BuiltinAgdaLiteral :: BuiltinId
BuiltinAgdaLitNat :: BuiltinId
BuiltinAgdaLitWord64 :: BuiltinId
BuiltinAgdaLitFloat :: BuiltinId
BuiltinAgdaLitChar :: BuiltinId
BuiltinAgdaLitString :: BuiltinId
BuiltinAgdaLitQName :: BuiltinId
BuiltinAgdaLitMeta :: BuiltinId
BuiltinAgdaClause :: BuiltinId
BuiltinAgdaClauseClause :: BuiltinId
BuiltinAgdaClauseAbsurd :: BuiltinId
BuiltinAgdaPattern :: BuiltinId
BuiltinAgdaPatVar :: BuiltinId
BuiltinAgdaPatCon :: BuiltinId
BuiltinAgdaPatDot :: BuiltinId
BuiltinAgdaPatLit :: BuiltinId
BuiltinAgdaPatProj :: BuiltinId
BuiltinAgdaPatAbsurd :: BuiltinId
BuiltinAgdaDefinitionFunDef :: BuiltinId
BuiltinAgdaDefinitionDataDef :: BuiltinId
BuiltinAgdaDefinitionRecordDef :: BuiltinId
BuiltinAgdaDefinitionDataConstructor :: BuiltinId
BuiltinAgdaDefinitionPostulate :: BuiltinId
BuiltinAgdaDefinitionPrimitive :: BuiltinId
BuiltinAgdaDefinition :: BuiltinId
BuiltinAgdaMeta :: BuiltinId
BuiltinAgdaTCM :: BuiltinId
BuiltinAgdaTCMReturn :: BuiltinId
BuiltinAgdaTCMBind :: BuiltinId
BuiltinAgdaTCMUnify :: BuiltinId
BuiltinAgdaTCMTypeError :: BuiltinId
BuiltinAgdaTCMInferType :: BuiltinId
BuiltinAgdaTCMCheckType :: BuiltinId
BuiltinAgdaTCMNormalise :: BuiltinId
BuiltinAgdaTCMReduce :: BuiltinId
BuiltinAgdaTCMCatchError :: BuiltinId
BuiltinAgdaTCMGetContext :: BuiltinId
BuiltinAgdaTCMExtendContext :: BuiltinId
BuiltinAgdaTCMInContext :: BuiltinId
BuiltinAgdaTCMFreshName :: BuiltinId
BuiltinAgdaTCMDeclareDef :: BuiltinId
BuiltinAgdaTCMDeclarePostulate :: BuiltinId
BuiltinAgdaTCMDeclareData :: BuiltinId
BuiltinAgdaTCMDefineData :: BuiltinId
BuiltinAgdaTCMDefineFun :: BuiltinId
BuiltinAgdaTCMGetType :: BuiltinId
BuiltinAgdaTCMGetDefinition :: BuiltinId
BuiltinAgdaTCMBlock :: BuiltinId
BuiltinAgdaTCMCommit :: BuiltinId
BuiltinAgdaTCMQuoteTerm :: BuiltinId
BuiltinAgdaTCMUnquoteTerm :: BuiltinId
BuiltinAgdaTCMQuoteOmegaTerm :: BuiltinId
BuiltinAgdaTCMIsMacro :: BuiltinId
BuiltinAgdaTCMWithNormalisation :: BuiltinId
BuiltinAgdaTCMWithReconstructed :: BuiltinId
BuiltinAgdaTCMWithExpandLast :: BuiltinId
BuiltinAgdaTCMWithReduceDefs :: BuiltinId
BuiltinAgdaTCMAskNormalisation :: BuiltinId
BuiltinAgdaTCMAskReconstructed :: BuiltinId
BuiltinAgdaTCMAskExpandLast :: BuiltinId
BuiltinAgdaTCMAskReduceDefs :: BuiltinId
BuiltinAgdaTCMFormatErrorParts :: BuiltinId
BuiltinAgdaTCMDebugPrint :: BuiltinId
BuiltinAgdaTCMNoConstraints :: BuiltinId
BuiltinAgdaTCMWorkOnTypes :: BuiltinId
BuiltinAgdaTCMRunSpeculative :: BuiltinId
BuiltinAgdaTCMExec :: BuiltinId
BuiltinAgdaTCMGetInstances :: BuiltinId
BuiltinAgdaTCMSolveInstances :: BuiltinId
BuiltinAgdaTCMPragmaForeign :: BuiltinId
BuiltinAgdaTCMPragmaCompile :: BuiltinId
BuiltinAgdaBlocker :: BuiltinId
BuiltinAgdaBlockerAny :: BuiltinId
BuiltinAgdaBlockerAll :: BuiltinId
BuiltinAgdaBlockerMeta :: BuiltinId

-- | A primitive name, defined by the <tt>primitive</tt> block.
data PrimitiveId
PrimConId :: PrimitiveId
PrimIdElim :: PrimitiveId
PrimIMin :: PrimitiveId
PrimIMax :: PrimitiveId
PrimINeg :: PrimitiveId
PrimPartial :: PrimitiveId
PrimPartialP :: PrimitiveId
PrimSubOut :: PrimitiveId
PrimGlue :: PrimitiveId
Prim_glue :: PrimitiveId
Prim_unglue :: PrimitiveId
Prim_glueU :: PrimitiveId
Prim_unglueU :: PrimitiveId
PrimFaceForall :: PrimitiveId
PrimComp :: PrimitiveId
PrimPOr :: PrimitiveId
PrimTrans :: PrimitiveId
PrimDepIMin :: PrimitiveId
PrimIdFace :: PrimitiveId
PrimIdPath :: PrimitiveId
PrimHComp :: PrimitiveId
PrimShowInteger :: PrimitiveId
PrimNatPlus :: PrimitiveId
PrimNatMinus :: PrimitiveId
PrimNatTimes :: PrimitiveId
PrimNatDivSucAux :: PrimitiveId
PrimNatModSucAux :: PrimitiveId
PrimNatEquality :: PrimitiveId
PrimNatLess :: PrimitiveId
PrimShowNat :: PrimitiveId
PrimWord64FromNat :: PrimitiveId
PrimWord64ToNat :: PrimitiveId
PrimWord64ToNatInjective :: PrimitiveId
PrimLevelZero :: PrimitiveId
PrimLevelSuc :: PrimitiveId
PrimLevelMax :: PrimitiveId
PrimFloatEquality :: PrimitiveId
PrimFloatInequality :: PrimitiveId
PrimFloatLess :: PrimitiveId
PrimFloatIsInfinite :: PrimitiveId
PrimFloatIsNaN :: PrimitiveId
PrimFloatIsNegativeZero :: PrimitiveId
PrimFloatIsSafeInteger :: PrimitiveId
PrimFloatToWord64 :: PrimitiveId
PrimFloatToWord64Injective :: PrimitiveId
PrimNatToFloat :: PrimitiveId
PrimIntToFloat :: PrimitiveId
PrimFloatRound :: PrimitiveId
PrimFloatFloor :: PrimitiveId
PrimFloatCeiling :: PrimitiveId
PrimFloatToRatio :: PrimitiveId
PrimRatioToFloat :: PrimitiveId
PrimFloatDecode :: PrimitiveId
PrimFloatEncode :: PrimitiveId
PrimShowFloat :: PrimitiveId
PrimFloatPlus :: PrimitiveId
PrimFloatMinus :: PrimitiveId
PrimFloatTimes :: PrimitiveId
PrimFloatNegate :: PrimitiveId
PrimFloatDiv :: PrimitiveId
PrimFloatPow :: PrimitiveId
PrimFloatSqrt :: PrimitiveId
PrimFloatExp :: PrimitiveId
PrimFloatLog :: PrimitiveId
PrimFloatSin :: PrimitiveId
PrimFloatCos :: PrimitiveId
PrimFloatTan :: PrimitiveId
PrimFloatASin :: PrimitiveId
PrimFloatACos :: PrimitiveId
PrimFloatATan :: PrimitiveId
PrimFloatATan2 :: PrimitiveId
PrimFloatSinh :: PrimitiveId
PrimFloatCosh :: PrimitiveId
PrimFloatTanh :: PrimitiveId
PrimFloatASinh :: PrimitiveId
PrimFloatACosh :: PrimitiveId
PrimFloatATanh :: PrimitiveId
PrimCharEquality :: PrimitiveId
PrimIsLower :: PrimitiveId
PrimIsDigit :: PrimitiveId
PrimIsAlpha :: PrimitiveId
PrimIsSpace :: PrimitiveId
PrimIsAscii :: PrimitiveId
PrimIsLatin1 :: PrimitiveId
PrimIsPrint :: PrimitiveId
PrimIsHexDigit :: PrimitiveId
PrimToUpper :: PrimitiveId
PrimToLower :: PrimitiveId
PrimCharToNat :: PrimitiveId
PrimCharToNatInjective :: PrimitiveId
PrimNatToChar :: PrimitiveId
PrimShowChar :: PrimitiveId
PrimStringToList :: PrimitiveId
PrimStringToListInjective :: PrimitiveId
PrimStringFromList :: PrimitiveId
PrimStringFromListInjective :: PrimitiveId
PrimStringAppend :: PrimitiveId
PrimStringEquality :: PrimitiveId
PrimShowString :: PrimitiveId
PrimStringUncons :: PrimitiveId
PrimErase :: PrimitiveId
PrimEraseEquality :: PrimitiveId
PrimForce :: PrimitiveId
PrimForceLemma :: PrimitiveId
PrimQNameEquality :: PrimitiveId
PrimQNameLess :: PrimitiveId
PrimShowQName :: PrimitiveId
PrimQNameFixity :: PrimitiveId
PrimQNameToWord64s :: PrimitiveId
PrimQNameToWord64sInjective :: PrimitiveId
PrimMetaEquality :: PrimitiveId
PrimMetaLess :: PrimitiveId
PrimShowMeta :: PrimitiveId
PrimMetaToNat :: PrimitiveId
PrimMetaToNatInjective :: PrimitiveId
PrimLockUniv :: PrimitiveId

-- | <a>Nothing</a> is used if no verbosity options have been given, thus
--   making it possible to handle the default case relatively quickly. Note
--   that <a>Nothing</a> corresponds to a trie with verbosity level 1 for
--   the empty path.
type Verbosity = Maybe (Trie VerboseKeyItem VerboseLevel)
type VerboseKey = String
type VerboseLevel = Int
class MonadTCEnv m => MonadAddContext m

-- | <tt>addCtx x arg cont</tt> add a variable to the context.
--   
--   Chooses an unused <a>Name</a>.
--   
--   Warning: Does not update module parameter substitution!
addCtx :: MonadAddContext m => Name -> Dom Type -> m a -> m a

-- | Add a let bound variable to the context
addLetBinding' :: MonadAddContext m => Origin -> Name -> Term -> Dom Type -> m a -> m a

-- | Update the context. Requires a substitution that transports things
--   living in the old context to the new.
updateContext :: MonadAddContext m => Substitution -> (Context -> Context) -> m a -> m a
withFreshName :: MonadAddContext m => Range -> ArgName -> (Name -> m a) -> m a

-- | <tt>addCtx x arg cont</tt> add a variable to the context.
--   
--   Chooses an unused <a>Name</a>.
--   
--   Warning: Does not update module parameter substitution!
addCtx :: (MonadAddContext m, MonadAddContext n, MonadTransControl t, t n ~ m) => Name -> Dom Type -> m a -> m a

-- | Add a let bound variable to the context
addLetBinding' :: (MonadAddContext m, MonadAddContext n, MonadTransControl t, t n ~ m) => Origin -> Name -> Term -> Dom Type -> m a -> m a

-- | Update the context. Requires a substitution that transports things
--   living in the old context to the new.
updateContext :: (MonadAddContext m, MonadAddContext n, MonadTransControl t, t n ~ m) => Substitution -> (Context -> Context) -> m a -> m a
withFreshName :: (MonadAddContext m, MonadAddContext n, MonadTransControl t, t n ~ m) => Range -> ArgName -> (Name -> m a) -> m a
class (Applicative m, MonadTCEnv m, ReadTCState m, HasOptions m) => MonadReduce m
liftReduce :: MonadReduce m => ReduceM a -> m a
liftReduce :: (MonadReduce m, MonadTrans t, MonadReduce n, t n ~ m) => ReduceM a -> m a
class ReadTCState m => MonadStatistics m
modifyCounter :: MonadStatistics m => String -> (Integer -> Integer) -> m ()
modifyCounter :: (MonadStatistics m, MonadStatistics n, MonadTrans t, t n ~ m) => String -> (Integer -> Integer) -> m ()
type Statistics = Map String Integer

-- | The backends are responsible for parsing their own pragmas.
data CompilerPragma
CompilerPragma :: Range -> String -> CompilerPragma
type Offset = Nat
data TCEnv
TCEnv :: Context -> LetBindings -> ModuleName -> Maybe AbsolutePath -> [(ModuleName, Nat)] -> [TopLevelModuleName] -> Maybe MutualId -> TerminationCheck () -> CoverageCheck -> Bool -> Bool -> Bool -> Bool -> Bool -> Set ProblemId -> Maybe ProblemId -> AbstractMode -> Relevance -> Quantity -> Bool -> Bool -> Bool -> Bool -> Range -> Range -> IPClause -> Maybe (Closure Call) -> HighlightingLevel -> HighlightingMethod -> ExpandHidden -> Maybe QName -> Simplification -> AllowedReductions -> ReduceDefs -> Bool -> Int -> Bool -> Bool -> Bool -> Bool -> UnquoteFlags -> !Int -> Bool -> [QName] -> Bool -> CheckpointId -> Map CheckpointId Substitution -> DoGeneralize -> Map QName GeneralizedValue -> Maybe BackendName -> Bool -> Bool -> !Maybe Int -> !Maybe OpaqueId -> TCEnv
[envContext] :: TCEnv -> Context
[envLetBindings] :: TCEnv -> LetBindings
[envCurrentModule] :: TCEnv -> ModuleName

-- | The path to the file that is currently being type-checked.
--   <a>Nothing</a> if we do not have a file (like in interactive mode see
--   <tt>CommandLine</tt>).
[envCurrentPath] :: TCEnv -> Maybe AbsolutePath

-- | anonymous modules and their number of free variables
[envAnonymousModules] :: TCEnv -> [(ModuleName, Nat)]

-- | The module stack with the entry being the top-level module as Agda
--   chases modules. It will be empty if there is no main module, will have
--   a single entry for the top level module, or more when descending past
--   the main module. This is used to detect import cycles and in some
--   cases highlighting behavior. The level of a given module is not
--   necessarily the same as the length, in the module dependency graph, of
--   the shortest path from the top-level module; it depends on in which
--   order Agda chooses to chase dependencies.
[envImportPath] :: TCEnv -> [TopLevelModuleName]

-- | the current (if any) mutual block
[envMutualBlock] :: TCEnv -> Maybe MutualId

-- | are we inside the scope of a termination pragma
[envTerminationCheck] :: TCEnv -> TerminationCheck ()

-- | are we inside the scope of a coverage pragma
[envCoverageCheck] :: TCEnv -> CoverageCheck

-- | are we inside a make-case (if so, ignore forcing analysis in unifier)
[envMakeCase] :: TCEnv -> Bool

-- | Are we currently in the process of solving active constraints?
[envSolvingConstraints] :: TCEnv -> Bool

-- | Have we stepped into the where-declarations of a clause? Everything
--   under a <tt>where</tt> will be checked with this flag on.
[envCheckingWhere] :: TCEnv -> Bool

-- | Are we working on types? Turned on by <tt>workOnTypes</tt>.
[envWorkingOnTypes] :: TCEnv -> Bool

-- | Are we allowed to assign metas?
[envAssignMetas] :: TCEnv -> Bool
[envActiveProblems] :: TCEnv -> Set ProblemId

-- | If inside a <tt>runUnquoteM</tt> call, stores the top-level problem id
--   assigned to the invokation. We use this to decide which instance
--   constraints originate from the current call and which come from the
--   outside, for the purpose of a <tt>solveInstanceConstraints</tt> inside
--   <tt>noConstraints</tt> only failing for local instance constraints.
[envUnquoteProblem] :: TCEnv -> Maybe ProblemId

-- | When checking the typesignature of a public definition or the body of
--   a non-abstract definition this is true. To prevent information about
--   abstract things leaking outside the module.
[envAbstractMode] :: TCEnv -> AbstractMode

-- | Are we checking an irrelevant argument? (=<tt>Irrelevant</tt>) Then
--   top-level irrelevant declarations are enabled. Other value:
--   <tt>Relevant</tt>, then only relevant decls. are available.
[envRelevance] :: TCEnv -> Relevance

-- | Are we checking a runtime-irrelevant thing? (=<a>Quantity0</a>) Then
--   runtime-irrelevant things are usable.
[envQuantity] :: TCEnv -> Quantity

-- | Is the "hard" compile-time mode enabled? In this mode the quantity
--   component of the environment is always zero, and every new definition
--   is treated as erased.
[envHardCompileTimeMode] :: TCEnv -> Bool

-- | Are we currently case-splitting on a strict datatype (i.e. in SSet)?
--   If yes, the pattern-matching unifier will solve reflexive equations
--   even --without-K.
[envSplitOnStrict] :: TCEnv -> Bool

-- | Sometimes we want to disable display forms.
[envDisplayFormsEnabled] :: TCEnv -> Bool

-- | Fold let-bindings when printing terms (default: True)
[envFoldLetBindings] :: TCEnv -> Bool
[envRange] :: TCEnv -> Range

-- | Interactive highlighting uses this range rather than <a>envRange</a>.
[envHighlightingRange] :: TCEnv -> Range

-- | What is the current clause we are type-checking? Will be recorded in
--   interaction points in this clause.
[envClause] :: TCEnv -> IPClause

-- | what we're doing at the moment
[envCall] :: TCEnv -> Maybe (Closure Call)

-- | Set to <a>None</a> when imported modules are type-checked.
[envHighlightingLevel] :: TCEnv -> HighlightingLevel
[envHighlightingMethod] :: TCEnv -> HighlightingMethod

-- | When type-checking an alias f=e, we do not want to insert hidden
--   arguments in the end, because these will become unsolved metas.
[envExpandLast] :: TCEnv -> ExpandHidden

-- | We are reducing an application of this function. (For tracking of
--   incomplete matches.)
[envAppDef] :: TCEnv -> Maybe QName

-- | Did we encounter a simplification (proper match) during the current
--   reduction process?
[envSimplification] :: TCEnv -> Simplification
[envAllowedReductions] :: TCEnv -> AllowedReductions
[envReduceDefs] :: TCEnv -> ReduceDefs
[envReconstructed] :: TCEnv -> Bool

-- | Injectivity can cause non-termination for unsolvable contraints (#431,
--   #3067). Keep a limit on the nesting depth of injectivity uses.
[envInjectivityDepth] :: TCEnv -> Int

-- | When <tt>True</tt>, the conversion checker will consider all term
--   constructors as injective, including blocked function applications and
--   metas. Warning: this should only be used when not assigning any metas
--   (e.g. when <tt>envAssignMetas</tt> is <tt>False</tt> or when running
--   <tt>pureEqualTerms</tt>) or else we get non-unique meta solutions.
[envCompareBlocked] :: TCEnv -> Bool

-- | When <tt>True</tt>, types will be omitted from printed pi types if
--   they can be inferred.
[envPrintDomainFreePi] :: TCEnv -> Bool

-- | When <tt>True</tt>, throw away meta numbers and meta elims. This is
--   used for reifying terms for feeding into the user's source code, e.g.,
--   for the interaction tactics <tt>solveAll</tt>.
[envPrintMetasBare] :: TCEnv -> Bool

-- | Used by the scope checker to make sure that certain forms of
--   expressions are not used inside dot patterns: extended lambdas and
--   let-expressions.
[envInsideDotPattern] :: TCEnv -> Bool
[envUnquoteFlags] :: TCEnv -> UnquoteFlags

-- | Until we get a termination checker for instance search (#1743) we
--   limit the search depth to ensure termination.
[envInstanceDepth] :: TCEnv -> !Int
[envIsDebugPrinting] :: TCEnv -> Bool

-- | #3004: pattern lambdas with copatterns may refer to themselves. We
--   don't have a good story for what to do in this case, but at least
--   printing shouldn't loop. Here we keep track of which pattern lambdas
--   we are currently in the process of printing.
[envPrintingPatternLambdas] :: TCEnv -> [QName]

-- | Use call-by-need evaluation for reductions.
[envCallByNeed] :: TCEnv -> Bool

-- | Checkpoints track the evolution of the context as we go under binders
--   or refine it by pattern matching.
[envCurrentCheckpoint] :: TCEnv -> CheckpointId

-- | Keeps the substitution from each previous checkpoint to the current
--   context.
[envCheckpoints] :: TCEnv -> Map CheckpointId Substitution

-- | Should new metas generalized over.
[envGeneralizeMetas] :: TCEnv -> DoGeneralize

-- | Values for used generalizable variables.
[envGeneralizedVars] :: TCEnv -> Map QName GeneralizedValue

-- | Is some backend active at the moment, and if yes, which? NB: we only
--   store the <a>BackendName</a> here, otherwise <tt>instance Data
--   TCEnv</tt> is not derivable. The actual backend can be obtained from
--   the name via <a>stBackends</a>.
[envActiveBackendName] :: TCEnv -> Maybe BackendName

-- | Are we currently computing the overlap between two rewrite rules for
--   the purpose of confluence checking?
[envConflComputingOverlap] :: TCEnv -> Bool

-- | Are we currently in the process of executing an elaborate-and-give
--   interactive command?
[envCurrentlyElaborating] :: TCEnv -> Bool

-- | If this counter is <a>Nothing</a>, then syntactic equality checking is
--   unrestricted. If it is zero, then syntactic equality checking is not
--   run at all. If it is a positive number, then syntactic equality
--   checking is allowed to run, but the counter is decreased in the
--   failure continuation of <a>checkSyntacticEquality</a>.
[envSyntacticEqualityFuel] :: TCEnv -> !Maybe Int

-- | Unique identifier of the opaque block we are currently under, if any.
--   Used by the scope checker (to associate definitions to blocks), and by
--   the type checker (for unfolding control).
[envCurrentOpaqueId] :: TCEnv -> !Maybe OpaqueId
data Interface
Interface :: !Hash -> Text -> FileType -> [(TopLevelModuleName, Hash)] -> ModuleName -> TopLevelModuleName -> Map ModuleName Scope -> ScopeInfo -> Signature -> RemoteMetaStore -> DisplayForms -> Map QName Text -> Maybe Text -> BuiltinThings (PrimitiveId, QName) -> Map BackendName ForeignCodeStack -> HighlightingInfo -> [OptionsPragma] -> [OptionsPragma] -> PragmaOptions -> PatternSynDefns -> [TCWarning] -> Set QName -> Map OpaqueId OpaqueBlock -> Map QName OpaqueId -> Interface

-- | Hash of the source code.
[iSourceHash] :: Interface -> !Hash

-- | The source code. The source code is stored so that the HTML and LaTeX
--   backends can generate their output without having to re-read the
--   (possibly out of date) source code.
[iSource] :: Interface -> Text

-- | Source file type, determined from the file extension
[iFileType] :: Interface -> FileType

-- | Imported modules and their hashes.
[iImportedModules] :: Interface -> [(TopLevelModuleName, Hash)]

-- | Module name of this interface.
[iModuleName] :: Interface -> ModuleName

-- | The module's top-level module name.
[iTopLevelModuleName] :: Interface -> TopLevelModuleName

-- | Scope defined by this module.
--   
--   Andreas, AIM XX: Too avoid duplicate serialization, this field is not
--   serialized, so if you deserialize an interface, <tt>iScope</tt> will
--   be empty. But <tt>constructIScope</tt> constructs <a>iScope</a> from
--   <a>iInsideScope</a>.
[iScope] :: Interface -> Map ModuleName Scope

-- | Scope after we loaded this interface. Used in <a>AtTopLevel</a> and
--   <a>interactionLoop</a>.
[iInsideScope] :: Interface -> ScopeInfo
[iSignature] :: Interface -> Signature

-- | Instantiations for meta-variables that come from this module.
[iMetaBindings] :: Interface -> RemoteMetaStore

-- | Display forms added for imported identifiers.
[iDisplayForms] :: Interface -> DisplayForms

-- | User warnings for imported identifiers
[iUserWarnings] :: Interface -> Map QName Text

-- | Whether this module should raise a warning when imported
[iImportWarning] :: Interface -> Maybe Text
[iBuiltin] :: Interface -> BuiltinThings (PrimitiveId, QName)
[iForeignCode] :: Interface -> Map BackendName ForeignCodeStack
[iHighlighting] :: Interface -> HighlightingInfo

-- | Pragma options set in library files.
[iDefaultPragmaOptions] :: Interface -> [OptionsPragma]

-- | Pragma options set in the file.
[iFilePragmaOptions] :: Interface -> [OptionsPragma]

-- | Options/features used when checking the file (can be different from
--   options set directly in the file).
[iOptionsUsed] :: Interface -> PragmaOptions
[iPatternSyns] :: Interface -> PatternSynDefns
[iWarnings] :: Interface -> [TCWarning]
[iPartialDefs] :: Interface -> Set QName
[iOpaqueBlocks] :: Interface -> Map OpaqueId OpaqueBlock
[iOpaqueNames] :: Interface -> Map QName OpaqueId

-- | The constraints needed for <a>typeError</a> and similar.
type MonadTCError m = (MonadTCEnv m, ReadTCState m, MonadError TCErr m)
type BackendName = String
data TCState
TCSt :: !PreScopeState -> !PostScopeState -> !PersistentTCState -> TCState

-- | The state which is frozen after scope checking.
[stPreScopeState] :: TCState -> !PreScopeState

-- | The state which is modified after scope checking.
[stPostScopeState] :: TCState -> !PostScopeState

-- | State which is forever, like a diamond.
[stPersistentState] :: TCState -> !PersistentTCState
class (MonadTCEnv m, ReadTCState m) => MonadInteractionPoints m
freshInteractionId :: MonadInteractionPoints m => m InteractionId
freshInteractionId :: (MonadInteractionPoints m, MonadTrans t, MonadInteractionPoints n, t n ~ m) => m InteractionId
modifyInteractionPoints :: MonadInteractionPoints m => (InteractionPoints -> InteractionPoints) -> m ()
modifyInteractionPoints :: (MonadInteractionPoints m, MonadTrans t, MonadInteractionPoints n, t n ~ m) => (InteractionPoints -> InteractionPoints) -> m ()
class (HasBuiltins m, HasConstInfo m, MonadAddContext m, MonadDebug m, MonadReduce m, MonadTCEnv m, ReadTCState m) => PureTCM m
type RewriteRules = [RewriteRule]

-- | Signature lookup errors.
data SigError

-- | The name is not in the signature; default error message.
SigUnknown :: String -> SigError

-- | The name is not available, since it is abstract.
SigAbstract :: SigError

-- | The name is not available because it was defined in Cubical Agda, but
--   the current language is Erased Cubical Agda, and <tt>--erasure</tt> is
--   not active.
SigCubicalNotErasure :: SigError
data PrimFun
PrimFun :: QName -> Arity -> [Occurrence] -> ([Arg Term] -> Int -> ReduceM (Reduced MaybeReducedArgs Term)) -> PrimFun
[primFunName] :: PrimFun -> QName
[primFunArity] :: PrimFun -> Arity

-- | See <a>defArgOccurrences</a>.
[primFunArgOccurrences] :: PrimFun -> [Occurrence]
[primFunImplementation] :: PrimFun -> [Arg Term] -> Int -> ReduceM (Reduced MaybeReducedArgs Term)
data RunMetaOccursCheck
RunMetaOccursCheck :: RunMetaOccursCheck
DontRunMetaOccursCheck :: RunMetaOccursCheck

-- | We can either compare two terms at a given type, or compare two types
--   without knowing (or caring about) their sorts.
data CompareAs

-- | <tt>Type</tt> should not be <tt>Size</tt>. But currently, we do not
--   rely on this invariant.
AsTermsOf :: Type -> CompareAs

-- | Replaces <tt>AsTermsOf Size</tt>.
AsSizes :: CompareAs
AsTypes :: CompareAs

-- | An extension of <a>Comparison</a> to <tt>&gt;=</tt>.
data CompareDirection
DirEq :: CompareDirection
DirLeq :: CompareDirection
DirGeq :: CompareDirection

-- | Information about local meta-variables.
data MetaVariable
MetaVar :: MetaInfo -> MetaPriority -> Permutation -> Judgement MetaId -> MetaInstantiation -> Set Listener -> Frozen -> Maybe MetaId -> MetaVariable
[mvInfo] :: MetaVariable -> MetaInfo

-- | some metavariables are more eager to be instantiated
[mvPriority] :: MetaVariable -> MetaPriority

-- | a metavariable doesn't have to depend on all variables in the context,
--   this "permutation" will throw away the ones it does not depend on
[mvPermutation] :: MetaVariable -> Permutation
[mvJudgement] :: MetaVariable -> Judgement MetaId
[mvInstantiation] :: MetaVariable -> MetaInstantiation

-- | meta variables scheduled for eta-expansion but blocked by this one
[mvListeners] :: MetaVariable -> Set Listener

-- | are we past the point where we can instantiate this meta variable?
[mvFrozen] :: MetaVariable -> Frozen

-- | <tt>Just m</tt> means that this meta-variable will be equated to
--   <tt>m</tt> when the latter is unblocked. See
--   <a>blockTermOnProblem</a>.
[mvTwin] :: MetaVariable -> Maybe MetaId

-- | Monad service class for creating, solving and eta-expanding of
--   metavariables.
class (MonadConstraint m, MonadReduce m, MonadAddContext m, MonadTCEnv m, ReadTCState m, HasBuiltins m, HasConstInfo m, MonadDebug m) => MonadMetaSolver m

-- | Generate a new meta variable with some instantiation given. For
--   instance, the instantiation could be a
--   <a>PostponedTypeCheckingProblem</a>.
newMeta' :: MonadMetaSolver m => MetaInstantiation -> Frozen -> MetaInfo -> MetaPriority -> Permutation -> Judgement a -> m MetaId

-- | Assign to an open metavar which may not be frozen. First check that
--   metavar args are in pattern fragment. Then do extended occurs check on
--   given thing.
--   
--   Assignment is aborted by throwing a <tt>PatternErr</tt> via a call to
--   <tt>patternViolation</tt>. This error is caught by
--   <tt>catchConstraint</tt> during equality checking
--   (<tt>compareAtom</tt>) and leads to restoration of the original
--   constraints.
assignV :: MonadMetaSolver m => CompareDirection -> MetaId -> Args -> Term -> CompareAs -> m ()

-- | Directly instantiate the metavariable. Skip pattern check, occurs
--   check and frozen check. Used for eta expanding frozen metas.
assignTerm' :: (MonadMetaSolver m, MonadMetaSolver m) => MetaId -> [Arg ArgName] -> Term -> m ()

-- | Eta-expand a local meta-variable, if it is of the specified class.
--   Don't do anything if the meta-variable is a blocked term.
etaExpandMeta :: MonadMetaSolver m => [MetaClass] -> MetaId -> m ()

-- | Update the status of the metavariable
updateMetaVar :: MonadMetaSolver m => MetaId -> (MetaVariable -> MetaVariable) -> m ()

-- | 'speculateMetas fallback m' speculatively runs <tt>m</tt>, but if the
--   result is <a>RollBackMetas</a> any changes to metavariables are rolled
--   back and <tt>fallback</tt> is run instead.
speculateMetas :: MonadMetaSolver m => m () -> m KeepMetas -> m ()

-- | Information about an <tt>instance</tt> definition.
data InstanceInfo
InstanceInfo :: QName -> OverlapMode -> InstanceInfo

-- | Name of the "class" this is an instance for
[instanceClass] :: InstanceInfo -> QName

-- | Does this instance have a specified overlap mode?
[instanceOverlap] :: InstanceInfo -> OverlapMode
class Monad m => MonadBlock m

-- | `patternViolation b` aborts the current computation
patternViolation :: MonadBlock m => Blocker -> m a

-- | `patternViolation b` aborts the current computation
patternViolation :: (MonadBlock m, MonadTrans t, MonadBlock n, m ~ t n) => Blocker -> m a

-- | `catchPatternErr handle m` runs m, handling pattern violations with
--   <tt>handle</tt> (doesn't roll back the state)
catchPatternErr :: MonadBlock m => (Blocker -> m a) -> m a -> m a
data Reduced no yes
NoReduction :: no -> Reduced no yes
YesReduction :: Simplification -> yes -> Reduced no yes
data ProblemConstraint
PConstr :: Set ProblemId -> Blocker -> Closure Constraint -> ProblemConstraint
[constraintProblems] :: ProblemConstraint -> Set ProblemId
[constraintUnblocker] :: ProblemConstraint -> Blocker
[theConstraint] :: ProblemConstraint -> Closure Constraint

-- | The class of types which can be converted to <a>SomeBuiltin</a>.
class IsBuiltin a

-- | Convert this value to a builtin.
someBuiltin :: IsBuiltin a => a -> SomeBuiltin

-- | Get the identifier for this builtin, generally used for error
--   messages.
getBuiltinId :: IsBuiltin a => a -> String
type ContextEntry = Dom (Name, Type)
newtype Fields
Fields :: [(Name, Type)] -> Fields
data ForeignCode
ForeignCode :: Range -> String -> ForeignCode
data LetBinding
LetBinding :: Origin -> Term -> Dom Type -> LetBinding
[letOrigin] :: LetBinding -> Origin
[letTerm] :: LetBinding -> Term
[letType] :: LetBinding -> Dom Type
newtype Section
Section :: Telescope -> Section
[_secTelescope] :: Section -> Telescope
data PreScopeState
PreScopeState :: !HighlightingInfo -> !Signature -> !Set TopLevelModuleName -> !ModuleToSource -> !VisitedModules -> !ScopeInfo -> !PatternSynDefns -> !PatternSynDefns -> !Maybe (Set QName) -> !PragmaOptions -> !BuiltinThings PrimFun -> !DisplayForms -> !InteractionId -> !Map QName Text -> !Map QName Text -> !Maybe Text -> !Set QName -> !Map FilePath ProjectConfig -> !Map FilePath AgdaLibFile -> !RemoteMetaStore -> !HashMap QName QName -> !HashMap QName (HashSet QName) -> PreScopeState

-- | Highlighting info for tokens and Happy parser warnings (but not for
--   those tokens/warnings for which highlighting exists in
--   <a>stPostSyntaxInfo</a>).
[stPreTokens] :: PreScopeState -> !HighlightingInfo

-- | Imported declared identifiers. Those most not be serialized!
[stPreImports] :: PreScopeState -> !Signature

-- | The top-level modules imported by the current module.
[stPreImportedModules] :: PreScopeState -> !Set TopLevelModuleName
[stPreModuleToSource] :: PreScopeState -> !ModuleToSource
[stPreVisitedModules] :: PreScopeState -> !VisitedModules
[stPreScope] :: PreScopeState -> !ScopeInfo

-- | Pattern synonyms of the current file. Serialized.
[stPrePatternSyns] :: PreScopeState -> !PatternSynDefns

-- | Imported pattern synonyms. Must not be serialized!
[stPrePatternSynImports] :: PreScopeState -> !PatternSynDefns

-- | Collected generalizable variables; used during scope checking of terms
[stPreGeneralizedVars] :: PreScopeState -> !Maybe (Set QName)

-- | Options applying to the current file. <tt>OPTIONS</tt> pragmas only
--   affect this field.
[stPrePragmaOptions] :: PreScopeState -> !PragmaOptions
[stPreImportedBuiltins] :: PreScopeState -> !BuiltinThings PrimFun

-- | Display forms added by someone else to imported identifiers
[stPreImportedDisplayForms] :: PreScopeState -> !DisplayForms
[stPreFreshInteractionId] :: PreScopeState -> !InteractionId

-- | Imported <tt>UserWarning</tt>s, not to be stored in the
--   <tt>Interface</tt>
[stPreImportedUserWarnings] :: PreScopeState -> !Map QName Text

-- | Locally defined <tt>UserWarning</tt>s, to be stored in the
--   <tt>Interface</tt>
[stPreLocalUserWarnings] :: PreScopeState -> !Map QName Text

-- | Whether the current module should raise a warning when opened
[stPreWarningOnImport] :: PreScopeState -> !Maybe Text

-- | Imported partial definitions, not to be stored in the
--   <tt>Interface</tt>
[stPreImportedPartialDefs] :: PreScopeState -> !Set QName

-- | Map from directories to paths of closest enclosing .agda-lib files (or
--   <tt>Nothing</tt> if there are none).
[stPreProjectConfigs] :: PreScopeState -> !Map FilePath ProjectConfig

-- | Contents of .agda-lib files that have already been parsed.
[stPreAgdaLibFiles] :: PreScopeState -> !Map FilePath AgdaLibFile

-- | Used for meta-variables from other modules.
[stPreImportedMetaStore] :: PreScopeState -> !RemoteMetaStore

-- | Associates a copied name (the key) to its original name (the value).
--   Computed by the scope checker, used to compute opaque blocks.
[stPreCopiedNames] :: PreScopeState -> !HashMap QName QName

-- | Associates an original name (the key) to all its copies (the value).
--   Computed by the scope checker, used to compute opaque blocks.
[stPreNameCopies] :: PreScopeState -> !HashMap QName (HashSet QName)
data PostScopeState
PostScopeState :: !HighlightingInfo -> !DisambiguatedNames -> !LocalMetaStore -> !LocalMetaStore -> !InteractionPoints -> !Constraints -> !Constraints -> !Bool -> !Set QName -> !Signature -> !Map ModuleName CheckpointId -> !DisplayForms -> !Map BackendName ForeignCodeStack -> !Maybe (ModuleName, TopLevelModuleName) -> !Set QName -> !Set QName -> !ConcreteNames -> !Map RawName (DList RawName) -> !Map Name (DList RawName) -> !Statistics -> ![TCWarning] -> !Map MutualId MutualBlock -> !BuiltinThings PrimFun -> !MetaId -> !MutualId -> !ProblemId -> !CheckpointId -> !Int -> !NameId -> !OpaqueId -> !Bool -> !Bool -> !Bool -> !Bool -> !Set QName -> Map OpaqueId OpaqueBlock -> Map QName OpaqueId -> PostScopeState

-- | Highlighting info.
[stPostSyntaxInfo] :: PostScopeState -> !HighlightingInfo

-- | Disambiguation carried out by the type checker. Maps position of first
--   name character to disambiguated <tt><a>QName</a></tt> for each
--   <tt><a>AmbiguousQName</a></tt> already passed by the type checker.
[stPostDisambiguatedNames] :: PostScopeState -> !DisambiguatedNames

-- | Used for open meta-variables.
[stPostOpenMetaStore] :: PostScopeState -> !LocalMetaStore

-- | Used for local, instantiated meta-variables.
[stPostSolvedMetaStore] :: PostScopeState -> !LocalMetaStore
[stPostInteractionPoints] :: PostScopeState -> !InteractionPoints
[stPostAwakeConstraints] :: PostScopeState -> !Constraints
[stPostSleepingConstraints] :: PostScopeState -> !Constraints

-- | Dirty when a constraint is added, used to prevent pointer update.
--   Currently unused.
[stPostDirty] :: PostScopeState -> !Bool

-- | Definitions to be considered during occurs check. Initialized to the
--   current mutual block before the check. During occurs check, we remove
--   definitions from this set as soon we have checked them.
[stPostOccursCheckDefs] :: PostScopeState -> !Set QName

-- | Declared identifiers of the current file. These will be serialized
--   after successful type checking.
[stPostSignature] :: PostScopeState -> !Signature

-- | For each module remember the checkpoint corresponding to the orignal
--   context of the module parameters.
[stPostModuleCheckpoints] :: PostScopeState -> !Map ModuleName CheckpointId

-- | Display forms we add for imported identifiers
[stPostImportsDisplayForms] :: PostScopeState -> !DisplayForms

-- | <tt>{-# FOREIGN #-}</tt> code that should be included in the compiled
--   output. Does not include code for imported modules.
[stPostForeignCode] :: PostScopeState -> !Map BackendName ForeignCodeStack

-- | The current module is available after it has been type checked.
[stPostCurrentModule] :: PostScopeState -> !Maybe (ModuleName, TopLevelModuleName)
[stPostPendingInstances] :: PostScopeState -> !Set QName
[stPostTemporaryInstances] :: PostScopeState -> !Set QName

-- | Map keeping track of concrete names assigned to each abstract name
--   (can be more than one name in case the first one is shadowed)
[stPostConcreteNames] :: PostScopeState -> !ConcreteNames

-- | Map keeping track for each name root (= name w/o numeric suffixes)
--   what names with the same root have been used during a TC computation.
--   This information is used to build the <tt>ShadowingNames</tt> map.
[stPostUsedNames] :: PostScopeState -> !Map RawName (DList RawName)

-- | Map keeping track for each (abstract) name the list of all (raw) names
--   that it could maybe be shadowed by.
[stPostShadowingNames] :: PostScopeState -> !Map Name (DList RawName)

-- | Counters to collect various statistics about meta variables etc. Only
--   for current file.
[stPostStatistics] :: PostScopeState -> !Statistics
[stPostTCWarnings] :: PostScopeState -> ![TCWarning]
[stPostMutualBlocks] :: PostScopeState -> !Map MutualId MutualBlock
[stPostLocalBuiltins] :: PostScopeState -> !BuiltinThings PrimFun
[stPostFreshMetaId] :: PostScopeState -> !MetaId
[stPostFreshMutualId] :: PostScopeState -> !MutualId
[stPostFreshProblemId] :: PostScopeState -> !ProblemId
[stPostFreshCheckpointId] :: PostScopeState -> !CheckpointId
[stPostFreshInt] :: PostScopeState -> !Int
[stPostFreshNameId] :: PostScopeState -> !NameId
[stPostFreshOpaqueId] :: PostScopeState -> !OpaqueId
[stPostAreWeCaching] :: PostScopeState -> !Bool
[stPostPostponeInstanceSearch] :: PostScopeState -> !Bool
[stPostConsideringInstance] :: PostScopeState -> !Bool

-- | Should we instantiate away blocking metas? This can produce ill-typed
--   terms but they are often more readable. See issue #3606. Best set to
--   True only for calls to pretty*/reify to limit unwanted reductions.
[stPostInstantiateBlocking] :: PostScopeState -> !Bool

-- | Local partial definitions, to be stored in the <tt>Interface</tt>
[stPostLocalPartialDefs] :: PostScopeState -> !Set QName

-- | Associates opaque identifiers to their actual blocks.
[stPostOpaqueBlocks] :: PostScopeState -> Map OpaqueId OpaqueBlock

-- | Associates each opaque QName to the block it was defined in.
[stPostOpaqueIds] :: PostScopeState -> Map QName OpaqueId

-- | A part of the state which is not reverted when an error is thrown or
--   the state is reset.
data PersistentTCState
PersistentTCSt :: !DecodedModules -> !BiMap RawTopLevelModuleName ModuleNameHash -> CommandLineOptions -> InteractionOutputCallback -> !Benchmark -> !Statistics -> !Maybe LoadedFileCache -> [Backend_boot TCM] -> PersistentTCState
[stDecodedModules] :: PersistentTCState -> !DecodedModules

-- | Module name hashes for top-level module names (and vice versa).
[stPersistentTopLevelModuleNames] :: PersistentTCState -> !BiMap RawTopLevelModuleName ModuleNameHash
[stPersistentOptions] :: PersistentTCState -> CommandLineOptions

-- | Callback function to call when there is a response to give to the
--   interactive frontend. See the documentation of
--   <a>InteractionOutputCallback</a>.
[stInteractionOutputCallback] :: PersistentTCState -> InteractionOutputCallback

-- | Structure to track how much CPU time was spent on which Agda phase.
--   Needs to be a strict field to avoid space leaks!
[stBenchmark] :: PersistentTCState -> !Benchmark

-- | Should be strict field.
[stAccumStatistics] :: PersistentTCState -> !Statistics

-- | Cached typechecking state from the last loaded file. Should be
--   <tt>Nothing</tt> when checking imports.
[stPersistLoadedFileCache] :: PersistentTCState -> !Maybe LoadedFileCache

-- | Current backends with their options
[stPersistBackends] :: PersistentTCState -> [Backend_boot TCM]
type VisitedModules = Map TopLevelModuleName ModuleInfo
type BuiltinThings pf = Map SomeBuiltin (Builtin pf)
type DisplayForms = HashMap QName [LocalDisplayForm]

-- | Used for meta-variables from other modules (and in <a>Interface</a>s).
type RemoteMetaStore = HashMap MetaId RemoteMetaVariable

-- | Name disambiguation for the sake of highlighting.
data DisambiguatedName
DisambiguatedName :: NameKind -> QName -> DisambiguatedName
type DisambiguatedNames = IntMap DisambiguatedName
type ConcreteNames = Map Name [Name]

-- | Used for meta-variables from the current module.
type LocalMetaStore = Map MetaId MetaVariable

-- | Data structure managing the interaction points.
--   
--   We never remove interaction points from this map, only set their
--   <a>ipSolved</a> to <tt>True</tt>. (Issue #2368)
type InteractionPoints = BiMap InteractionId InteractionPoint
newtype CheckpointId
CheckpointId :: Int -> CheckpointId

-- | Foreign code fragments are stored in reversed order to support
--   efficient appending: head points to the latest pragma in module.
newtype ForeignCodeStack
ForeignCodeStack :: [ForeignCode] -> ForeignCodeStack
[getForeignCodeStack] :: ForeignCodeStack -> [ForeignCode]
newtype MutualId
MutId :: Int32 -> MutualId

-- | A mutual block of names in the signature.
data MutualBlock
MutualBlock :: MutualInfo -> Set QName -> MutualBlock

-- | The original info of the mutual block.
[mutualInfo] :: MutualBlock -> MutualInfo
[mutualNames] :: MutualBlock -> Set QName

-- | A block of opaque definitions.
data OpaqueBlock
OpaqueBlock :: {-# UNPACK #-} !OpaqueId -> HashSet QName -> HashSet QName -> Maybe OpaqueId -> Range -> OpaqueBlock

-- | Unique identifier for this block.
[opaqueId] :: OpaqueBlock -> {-# UNPACK #-} !OpaqueId

-- | Set of names we are allowed to unfold. After scope-checking, this set
--   should be transitively closed.
[opaqueUnfolding] :: OpaqueBlock -> HashSet QName

-- | Declarations contained in this abstract block.
[opaqueDecls] :: OpaqueBlock -> HashSet QName

-- | Pointer to an enclosing opaque block, if one exists.
[opaqueParent] :: OpaqueBlock -> Maybe OpaqueId

-- | Where is this opaque block?
[opaqueRange] :: OpaqueBlock -> Range
type DecodedModules = Map TopLevelModuleName ModuleInfo
data LoadedFileCache
LoadedFileCache :: !CachedTypeCheckLog -> !CurrentTypeCheckLog -> LoadedFileCache
[lfcCached] :: LoadedFileCache -> !CachedTypeCheckLog
[lfcCurrent] :: LoadedFileCache -> !CurrentTypeCheckLog

-- | A log of what the type checker does and states after the action is
--   completed. The cached version is stored first executed action first.
type CachedTypeCheckLog = [(TypeCheckAction, PostScopeState)]

-- | Like <a>CachedTypeCheckLog</a>, but storing the log for an ongoing
--   type checking of a module. Stored in reverse order (last performed
--   action first).
type CurrentTypeCheckLog = [(TypeCheckAction, PostScopeState)]

-- | A complete log for a module will look like this:
--   
--   <ul>
--   <li><a>Pragmas</a></li>
--   <li><a>EnterSection</a>, entering the main module.</li>
--   <li><a>Decl</a><i><a>EnterSection</a></i><a>LeaveSection</a>, for
--   declarations and nested modules</li>
--   <li><a>LeaveSection</a>, leaving the main module.</li>
--   </ul>
data TypeCheckAction
EnterSection :: !Erased -> !ModuleName -> !Telescope -> TypeCheckAction
LeaveSection :: !ModuleName -> TypeCheckAction

-- | Never a Section or ScopeDecl
Decl :: !Declaration -> TypeCheckAction
Pragmas :: !PragmaOptions -> TypeCheckAction

-- | When typechecking something of the following form:
--   
--   instance x : _ x = y
--   
--   it's not yet known where to add <tt>x</tt>, so we add it to a list of
--   unresolved instances and we'll deal with it later.
type TempInstanceTable = (InstanceTable, Set QName)
class Enum i => HasFresh i
freshLens :: HasFresh i => Lens' TCState i
nextFresh' :: HasFresh i => i -> i
class Monad m => MonadFresh i m
fresh :: MonadFresh i m => m i
fresh :: (MonadFresh i m, MonadTrans t, MonadFresh i n, t n ~ m) => m i

-- | Create a fresh name from <tt>a</tt>.
class FreshName a
freshName_ :: (FreshName a, MonadFresh NameId m) => a -> m Name

-- | A monad that has read and write access to the stConcreteNames part of
--   the TCState. Basically, this is a synonym for `MonadState
--   ConcreteNames m` (which cannot be used directly because of the
--   limitations of Haskell's typeclass system).
class Monad m => MonadStConcreteNames m
runStConcreteNames :: MonadStConcreteNames m => StateT ConcreteNames m a -> m a
useConcreteNames :: MonadStConcreteNames m => m ConcreteNames
modifyConcreteNames :: MonadStConcreteNames m => (ConcreteNames -> ConcreteNames) -> m ()

-- | Distinguishes between type-checked and scope-checked interfaces when
--   stored in the map of <a>VisitedModules</a>.
data ModuleCheckMode
ModuleScopeChecked :: ModuleCheckMode
ModuleTypeChecked :: ModuleCheckMode
class LensClosure b a | b -> a
lensClosure :: LensClosure b a => Lens' b (Closure a)
class LensTCEnv a
lensTCEnv :: LensTCEnv a => Lens' a TCEnv

-- | Why are we performing a modality check?
data WhyCheckModality

-- | Because --without-K is enabled, so the types of data constructors must
--   be usable at the context's modality.
ConstructorType :: WhyCheckModality

-- | Because --without-K is enabled, so the result type of clauses must be
--   usable at the context's modality.
IndexedClause :: WhyCheckModality

-- | Because --without-K is enabled, so any argument (second name) which
--   mentions a dotted argument (first name) must have a type which is
--   usable at the context's modality.
IndexedClauseArg :: Name -> Name -> WhyCheckModality

-- | Because we double-check the --cubical-compatible clauses. This is an
--   internal error!
GeneratedClause :: WhyCheckModality

-- | Information about whether an argument is forced by the type of a
--   function.
data IsForced
Forced :: IsForced
NotForced :: IsForced

-- | A candidate solution for an instance meta is a term with its type. It
--   may be the case that the candidate is not fully applied yet or of the
--   wrong type, hence the need for the type.
data Candidate
Candidate :: CandidateKind -> Term -> Type -> OverlapMode -> Candidate
[candidateKind] :: Candidate -> CandidateKind
[candidateTerm] :: Candidate -> Term
[candidateType] :: Candidate -> Type
[candidateOverlap] :: Candidate -> OverlapMode

-- | Parametrized since it is used without MetaId when creating a new meta.
data Judgement a
HasType :: a -> Comparison -> Type -> Judgement a
[jMetaId] :: Judgement a -> a

-- | are we checking (<tt>CmpLeq</tt>) or inferring (<tt>CmpEq</tt>) the
--   type?
[jComparison] :: Judgement a -> Comparison
[jMetaType] :: Judgement a -> Type
IsSort :: a -> Type -> Judgement a
[jMetaId] :: Judgement a -> a
[jMetaType] :: Judgement a -> Type
data DoGeneralize

-- | Generalize because it is a generalizable variable.
YesGeneralizeVar :: DoGeneralize

-- | Generalize because it is a metavariable and we're currently checking
--   the type of a generalizable variable (this should get the default
--   modality).
YesGeneralizeMeta :: DoGeneralize

-- | Don't generalize.
NoGeneralize :: DoGeneralize

-- | The value of a generalizable variable. This is created to be a
--   generalizable meta before checking the type to be generalized.
data GeneralizedValue
GeneralizedValue :: CheckpointId -> Term -> Type -> GeneralizedValue
[genvalCheckpoint] :: GeneralizedValue -> CheckpointId
[genvalTerm] :: GeneralizedValue -> Term
[genvalType] :: GeneralizedValue -> Type

-- | Meta variable priority: When we have an equation between
--   meta-variables, which one should be instantiated?
--   
--   Higher value means higher priority to be instantiated.
newtype MetaPriority
MetaPriority :: Int -> MetaPriority

-- | Solution status of meta.
data MetaInstantiation

-- | Solved by <a>Instantiation</a>.
InstV :: Instantiation -> MetaInstantiation

-- | Unsolved (open to solutions).
OpenMeta :: MetaKind -> MetaInstantiation

-- | Solved, but solution blocked by unsolved constraints.
BlockedConst :: Term -> MetaInstantiation

-- | Meta stands for value of the expression that is still to be type
--   checked.
PostponedTypeCheckingProblem :: Closure TypeCheckingProblem -> MetaInstantiation
data Listener
EtaExpand :: MetaId -> Listener
CheckConstraint :: Nat -> ProblemConstraint -> Listener

-- | Frozen meta variable cannot be instantiated by unification. This
--   serves to prevent the completion of a definition by its use outside of
--   the current block. (See issues 118, 288, 399).
data Frozen

-- | Do not instantiate.
Frozen :: Frozen
Instantiable :: Frozen

-- | Meta-variable instantiations.
data Instantiation
Instantiation :: [Arg String] -> Term -> Instantiation

-- | The solution is abstracted over these free variables.
[instTel] :: Instantiation -> [Arg String]

-- | The body of the solution.
[instBody] :: Instantiation -> Term
data TypeCheckingProblem
CheckExpr :: Comparison -> Expr -> Type -> TypeCheckingProblem
CheckArgs :: Comparison -> ExpandHidden -> Range -> [NamedArg Expr] -> Type -> Type -> (ArgsCheckState CheckedTarget -> TCM Term) -> TypeCheckingProblem
CheckProjAppToKnownPrincipalArg :: Comparison -> Expr -> ProjOrigin -> List1 QName -> Args -> Type -> Int -> Term -> Type -> PrincipalArgTypeMetas -> TypeCheckingProblem

-- | <tt>(λ (xs : t₀) → e) : t</tt> This is not an instance of
--   <a>CheckExpr</a> as the domain type has already been checked. For
--   example, when checking <tt>(λ (x y : Fin _) → e) : (x : Fin n) →
--   ?</tt> we want to postpone <tt>(λ (y : Fin n) → e) : ?</tt> where
--   <tt>Fin n</tt> is a <a>Type</a> rather than an <a>Expr</a>.
CheckLambda :: Comparison -> Arg (List1 (WithHiding Name), Maybe Type) -> Expr -> Type -> TypeCheckingProblem

-- | Quote the given term and check type against <a>Term</a>
DoQuoteTerm :: Comparison -> Term -> Type -> TypeCheckingProblem

-- | Information about remote meta-variables.
--   
--   Remote meta-variables are meta-variables originating in other modules.
--   These meta-variables are always instantiated. We do not retain all the
--   information about a local meta-variable when creating an interface:
--   
--   <ul>
--   <li>The <a>mvPriority</a> field is not needed, because the
--   meta-variable cannot be instantiated.</li>
--   <li>The <a>mvFrozen</a> field is not needed, because there is no point
--   in freezing instantiated meta-variables.</li>
--   <li>The <a>mvListeners</a> field is not needed, because no
--   meta-variable should be listening to this one.</li>
--   <li>The <a>mvTwin</a> field is not needed, because the meta-variable
--   has already been instantiated.</li>
--   <li>The <a>mvPermutation</a> is currently removed, but could be
--   retained if it turns out to be useful for something.</li>
--   <li>The only part of the <a>mvInfo</a> field that is kept is the
--   <a>miModality</a> field. The <a>miMetaOccursCheck</a> and
--   <a>miGeneralizable</a> fields are omitted, because the meta-variable
--   has already been instantiated. The <a>Range'</a> that is part of the
--   <a>miClosRange</a> field and the <a>miNameSuggestion</a> field are
--   omitted because instantiated meta-variables are typically not
--   presented to users. Finally the <a>Closure</a> part of the
--   <a>miClosRange</a> field is omitted because it can be large (at least
--   if we ignore potential sharing).</li>
--   </ul>
data RemoteMetaVariable
RemoteMetaVariable :: Instantiation -> Modality -> Judgement MetaId -> RemoteMetaVariable
[rmvInstantiation] :: RemoteMetaVariable -> Instantiation
[rmvModality] :: RemoteMetaVariable -> Modality
[rmvJudgement] :: RemoteMetaVariable -> Judgement MetaId

-- | Solving a <a>CheckArgs</a> constraint may or may not check the target
--   type. If it did, it returns a handle to any unsolved constraints.
data CheckedTarget
CheckedTarget :: Maybe ProblemId -> CheckedTarget
NotCheckedTarget :: CheckedTarget
data PrincipalArgTypeMetas
PrincipalArgTypeMetas :: Args -> Type -> PrincipalArgTypeMetas

-- | metas created for hidden and instance arguments in the principal
--   argument's type
[patmMetas] :: PrincipalArgTypeMetas -> Args

-- | principal argument's type, stripped of hidden and instance arguments
[patmRemainder] :: PrincipalArgTypeMetas -> Type
data ExpandHidden

-- | Add implicit arguments in the end until type is no longer hidden
--   <a>Pi</a>.
ExpandLast :: ExpandHidden

-- | Do not append implicit arguments.
DontExpandLast :: ExpandHidden

-- | Makes <tt>doExpandLast</tt> have no effect. Used to avoid implicit
--   insertion of arguments to metavariables.
ReallyDontExpandLast :: ExpandHidden
data ArgsCheckState a
ACState :: [Maybe Range] -> Elims -> [Maybe (Abs Constraint)] -> Type -> a -> ArgsCheckState a

-- | Ranges of checked arguments, where present. e.g. inserted implicits
--   have no correponding abstract syntax.
[acRanges] :: ArgsCheckState a -> [Maybe Range]

-- | Checked and inserted arguments so far.
[acElims] :: ArgsCheckState a -> Elims

-- | Constraints for the head so far, i.e. before applying the correponding
--   elim.
[acConstraints] :: ArgsCheckState a -> [Maybe (Abs Constraint)]

-- | Type for the rest of the application.
[acType] :: ArgsCheckState a -> Type
[acData] :: ArgsCheckState a -> a

-- | Interaction points are created by the scope checker who sets the
--   range. The meta variable is created by the type checker and then
--   hooked up to the interaction point.
data InteractionPoint
InteractionPoint :: Range -> Maybe MetaId -> Bool -> IPClause -> IPBoundary -> InteractionPoint

-- | The position of the interaction point.
[ipRange] :: InteractionPoint -> Range

-- | The meta variable, if any, holding the type etc.
[ipMeta] :: InteractionPoint -> Maybe MetaId

-- | Has this interaction point already been solved?
[ipSolved] :: InteractionPoint -> Bool

-- | The clause of the interaction point (if any). Used for case splitting.
[ipClause] :: InteractionPoint -> IPClause
[ipBoundary] :: InteractionPoint -> IPBoundary

-- | Which clause is an interaction point located in?
data IPClause
IPClause :: QName -> Int -> Type -> Maybe Substitution -> SpineClause -> Closure () -> IPClause

-- | The name of the function.
[ipcQName] :: IPClause -> QName

-- | The number of the clause of this function.
[ipcClauseNo] :: IPClause -> Int

-- | The type of the function
[ipcType] :: IPClause -> Type

-- | Module parameter substitution
[ipcWithSub] :: IPClause -> Maybe Substitution

-- | The original AST clause.
[ipcClause] :: IPClause -> SpineClause

-- | Environment for rechecking the clause.
[ipcClosure] :: IPClause -> Closure ()

-- | The interaction point is not in the rhs of a clause.
IPNoClause :: IPClause
type IPBoundary = IPBoundary' Term

-- | Flag to indicate whether the meta is overapplied in the constraint. A
--   meta is overapplied if it has more arguments than the size of the
--   telescope in its creation environment (as stored in MetaInfo).
data Overapplied
Overapplied :: Overapplied
NotOverapplied :: Overapplied
newtype IPBoundary' t
IPBoundary :: Map (IntMap Bool) t -> IPBoundary' t
[getBoundary] :: IPBoundary' t -> Map (IntMap Bool) t
type Sections = Map ModuleName Section
type RewriteRuleMap = HashMap QName RewriteRules

-- | Records information about the instances in the signature. Does not
--   deal with local instances.
data InstanceTable
InstanceTable :: DiscrimTree QName -> Map QName Int -> InstanceTable

-- | The actual discrimination tree for looking up instances with
[_itableTree] :: InstanceTable -> DiscrimTree QName

-- | For profiling, we store the number of instances on a per-class basis.
--   This lets us compare the result from the discrimination tree with all
--   the instances in scope, thus informing us how many validity checks
--   were skipped.
[_itableCounts] :: InstanceTable -> Map QName Int
type LocalDisplayForm = Open DisplayForm

-- | A structured presentation of a <a>Term</a> for reification into
--   <a>Syntax</a>.
data DisplayTerm

-- | <tt>(f vs | ws) es</tt>. The first <a>DisplayTerm</a> is the parent
--   function <tt>f</tt> with its args <tt>vs</tt>. The list of
--   <a>DisplayTerm</a>s are the with expressions <tt>ws</tt>. The
--   <a>Elims</a> are additional arguments <tt>es</tt> (possible in case
--   the with-application is of function type) or projections (if it is of
--   record type).
DWithApp :: DisplayTerm -> [DisplayTerm] -> Elims -> DisplayTerm

-- | <tt>c vs</tt>.
DCon :: ConHead -> ConInfo -> [Arg DisplayTerm] -> DisplayTerm

-- | <tt>d vs</tt>.
DDef :: QName -> [Elim' DisplayTerm] -> DisplayTerm

-- | <tt>.(v es)</tt>. See <a>DTerm'</a>.
DDot' :: Term -> Elims -> DisplayTerm

-- | <tt>v es</tt>. This is a frozen elimination that is not always safe to
--   run, because display forms may be ill-typed. (See issue #6476.)
DTerm' :: Term -> Elims -> DisplayTerm

-- | Non-linear (non-constructor) first-order pattern.
data NLPat

-- | Matches anything (modulo non-linearity) that only contains bound
--   variables that occur in the given arguments.
PVar :: !Int -> [Arg Int] -> NLPat

-- | Matches <tt>f es</tt>
PDef :: QName -> PElims -> NLPat

-- | Matches <tt>λ x → t</tt>
PLam :: ArgInfo -> Abs NLPat -> NLPat

-- | Matches <tt>(x : A) → B</tt>
PPi :: Dom NLPType -> Abs NLPType -> NLPat

-- | Matches a sort of the given shape.
PSort :: NLPSort -> NLPat

-- | Matches <tt>x es</tt> where x is a lambda-bound variable
PBoundVar :: {-# UNPACK #-} !Int -> PElims -> NLPat

-- | Matches the term modulo β (ideally βη).
PTerm :: Term -> NLPat
type PElims = [Elim' NLPat]
data NLPType
NLPType :: NLPSort -> NLPat -> NLPType
[nlpTypeSort] :: NLPType -> NLPSort
[nlpTypeUnEl] :: NLPType -> NLPat
data NLPSort
PUniv :: Univ -> NLPat -> NLPSort
PInf :: Univ -> Integer -> NLPSort
PSizeUniv :: NLPSort
PLockUniv :: NLPSort
PLevelUniv :: NLPSort
PIntervalUniv :: NLPSort

-- | Rewrite rules can be added independently from function clauses.
data RewriteRule
RewriteRule :: QName -> Telescope -> QName -> PElims -> Term -> Type -> Bool -> RewriteRule

-- | Name of rewrite rule <tt>q : Γ → f ps ≡ rhs</tt> where <tt>≡</tt> is
--   the rewrite relation.
[rewName] :: RewriteRule -> QName

-- | <tt>Γ</tt>.
[rewContext] :: RewriteRule -> Telescope

-- | <tt>f</tt>.
[rewHead] :: RewriteRule -> QName

-- | <tt>Γ ⊢ f ps : t</tt>.
[rewPats] :: RewriteRule -> PElims

-- | <tt>Γ ⊢ rhs : t</tt>.
[rewRHS] :: RewriteRule -> Term

-- | <tt>Γ ⊢ t</tt>.
[rewType] :: RewriteRule -> Type

-- | Was this rewrite rule created from a clause in the definition of the
--   function?
[rewFromClause] :: RewriteRule -> Bool
data Defn

-- | Postulate.
AxiomDefn :: AxiomData -> Defn

-- | Data or record type signature that doesn't yet have a definition.
DataOrRecSigDefn :: DataOrRecSigData -> Defn

-- | Generalizable variable (introduced in <tt>generalize</tt> block).
GeneralizableVar :: Defn

-- | Returned by <tt>getConstInfo</tt> if definition is abstract.
AbstractDefn :: Defn -> Defn
FunctionDefn :: FunctionData -> Defn
DatatypeDefn :: DatatypeData -> Defn
RecordDefn :: RecordData -> Defn
ConstructorDefn :: ConstructorData -> Defn

-- | Primitive or builtin functions.
PrimitiveDefn :: PrimitiveData -> Defn
PrimitiveSortDefn :: PrimitiveSortData -> Defn
data NumGeneralizableArgs
NoGeneralizableArgs :: NumGeneralizableArgs

-- | When lambda-lifting new args are generalizable if
--   <a>SomeGeneralizableArgs</a>, also when the number is zero.
SomeGeneralizableArgs :: !Int -> NumGeneralizableArgs
type CompiledRepresentation = Map BackendName [CompilerPragma]
type Face = [(Term, Bool)]

-- | Additional information for extended lambdas.
data ExtLamInfo
ExtLamInfo :: ModuleName -> Bool -> !Maybe System -> ExtLamInfo

-- | For complicated reasons the scope checker decides the QName of a
--   pattern lambda, and thus its module. We really need to decide the
--   module during type checking though, since if the lambda appears in a
--   refined context the module picked by the scope checker has very much
--   the wrong parameters.
[extLamModule] :: ExtLamInfo -> ModuleName

-- | Was this definition created from an absurd lambda <tt>λ ()</tt>?
[extLamAbsurd] :: ExtLamInfo -> Bool
[extLamSys] :: ExtLamInfo -> !Maybe System

-- | Additional information for projection <a>Function</a>s.
data Projection
Projection :: Maybe QName -> QName -> Arg QName -> Int -> ProjLams -> Projection

-- | <tt>Nothing</tt> if only projection-like, <tt>Just r</tt> if record
--   projection. The <tt>r</tt> is the name of the record type projected
--   from. This field is updated by module application.
[projProper] :: Projection -> Maybe QName

-- | The original projection name (current name could be from module
--   application).
[projOrig] :: Projection -> QName

-- | Type projected from. Original record type if <tt>projProper =
--   Just{}</tt>. Also stores <tt>ArgInfo</tt> of the principal argument.
--   This field is unchanged by module application.
[projFromType] :: Projection -> Arg QName

-- | Index of the record argument. Start counting with 1, because 0 means
--   that it is already applied to the record value. This can happen in
--   module instantiation, but then either the record value is <tt>var
--   0</tt>, or <tt>funProjection == Left _</tt>.
[projIndex] :: Projection -> Int

-- | Term <tt>t</tt> to be be applied to record parameters and record
--   value. The parameters will be dropped. In case of a proper projection,
--   a postfix projection application will be created: <tt>t = pars r -&gt;
--   r .p</tt> (Invariant: the number of abstractions equals
--   <a>projIndex</a>.) In case of a projection-like function, just the
--   function symbol is returned as <a>Def</a>: <tt>t = pars -&gt; f</tt>.
[projLams] :: Projection -> ProjLams

-- | Abstractions to build projection function (dropping parameters).
newtype ProjLams
ProjLams :: [Arg ArgName] -> ProjLams
[getProjLams] :: ProjLams -> [Arg ArgName]

-- | Should a record type admit eta-equality?
data EtaEquality

-- | User specifed 'eta-equality' or 'no-eta-equality'.
Specified :: !HasEta -> EtaEquality
[theEtaEquality] :: EtaEquality -> !HasEta

-- | Positivity checker inferred whether eta is safe.
Inferred :: !HasEta -> EtaEquality
[theEtaEquality] :: EtaEquality -> !HasEta
data FunctionFlag

-- | Should calls to this function be normalised at compile-time?
FunStatic :: FunctionFlag

-- | Should calls to this function be inlined by the compiler?
FunInline :: FunctionFlag

-- | Is this function a macro?
FunMacro :: FunctionFlag

-- | Is this function <tt>INJECTIVE_FOR_INFERENCE</tt>? Indicates whether
--   the first-order shortcut should be applied to the definition.
FunFirstOrder :: FunctionFlag

-- | Was <tt>--erasure</tt> in effect when the function was defined? (This
--   can affect the type of a projection.)
FunErasure :: FunctionFlag

-- | Is the function abstract?
FunAbstract :: FunctionFlag

-- | Is this function a descendant of a field (typically, a projection)?
FunProj :: FunctionFlag
data CompKit
CompKit :: Maybe QName -> Maybe QName -> CompKit
[nameOfHComp] :: CompKit -> Maybe QName
[nameOfTransp] :: CompKit -> Maybe QName
data AxiomData
AxiomData :: Bool -> AxiomData

-- | Can transp for this postulate be constant? Set to <tt>True</tt> for
--   bultins like String.
[_axiomConstTransp] :: AxiomData -> Bool
data DataOrRecSigData
DataOrRecSigData :: Int -> DataOrRecSigData
[_datarecPars] :: DataOrRecSigData -> Int
data FunctionData
FunctionData :: [Clause] -> Maybe CompiledClauses -> Maybe SplitTree -> Maybe Compiled -> [Clause] -> FunctionInverse -> Maybe [QName] -> Either ProjectionLikenessMissing Projection -> SmallSet FunctionFlag -> Maybe Bool -> Maybe ExtLamInfo -> Maybe QName -> Maybe QName -> IsOpaque -> FunctionData
[_funClauses] :: FunctionData -> [Clause]

-- | <a>Nothing</a> while function is still type-checked. <tt>Just cc</tt>
--   after type and coverage checking and translation to case trees.
[_funCompiled] :: FunctionData -> Maybe CompiledClauses

-- | The split tree constructed by the coverage checker. Needed to
--   re-compile the clauses after forcing translation.
[_funSplitTree] :: FunctionData -> Maybe SplitTree

-- | Intermediate representation for compiler backends.
[_funTreeless] :: FunctionData -> Maybe Compiled

-- | Covering clauses computed by coverage checking. Erased by (IApply)
--   confluence checking(?)
[_funCovering] :: FunctionData -> [Clause]
[_funInv] :: FunctionData -> FunctionInverse

-- | Mutually recursive functions, <tt>data</tt>s and <tt>record</tt>s.
--   Does include this function. Empty list if not recursive.
--   <tt>Nothing</tt> if not yet computed (by positivity checker).
[_funMutual] :: FunctionData -> Maybe [QName]

-- | Is it a record projection? If yes, then return the name of the record
--   type and index of the record argument. Start counting with 1, because
--   0 means that it is already applied to the record. (Can happen in
--   module instantiation.) This information is used in the termination
--   checker.
[_funProjection] :: FunctionData -> Either ProjectionLikenessMissing Projection

-- | Various boolean flags pertaining to the function definition, see
--   <a>FunctionFlag</a>.
[_funFlags] :: FunctionData -> SmallSet FunctionFlag

-- | Has this function been termination checked? Did it pass?
[_funTerminates] :: FunctionData -> Maybe Bool

-- | Is this function generated from an extended lambda? If yes, then
--   return the number of hidden and non-hidden lambda-lifted arguments.
[_funExtLam] :: FunctionData -> Maybe ExtLamInfo

-- | Is this a generated with-function? If yes, then what's the name of the
--   parent function?
[_funWith] :: FunctionData -> Maybe QName

-- | Is this a helper for one of the Kan operations (transp, hcomp) on data
--   types/records? If so, for which data type?
[_funIsKanOp] :: FunctionData -> Maybe QName

-- | Is this function opaque? If so, and we're not in an opaque block that
--   includes this function('s name), it will be treated abstractly.
[_funOpaque] :: FunctionData -> IsOpaque
data DatatypeData
DatatypeData :: Nat -> Nat -> Maybe Clause -> [QName] -> Sort -> Maybe [QName] -> IsAbstract -> [QName] -> Maybe QName -> Maybe QName -> DatatypeData

-- | Number of parameters.
[_dataPars] :: DatatypeData -> Nat

-- | Number of indices.
[_dataIxs] :: DatatypeData -> Nat

-- | This might be in an instantiated module.
[_dataClause] :: DatatypeData -> Maybe Clause

-- | Constructor names, ordered according to the order of their definition.
[_dataCons] :: DatatypeData -> [QName]
[_dataSort] :: DatatypeData -> Sort

-- | Mutually recursive functions, <tt>data</tt>s and <tt>record</tt>s.
--   Does include this data type. Empty if not recursive. <tt>Nothing</tt>
--   if not yet computed (by positivity checker).
[_dataMutual] :: DatatypeData -> Maybe [QName]
[_dataAbstr] :: DatatypeData -> IsAbstract

-- | Path constructor names (subset of <tt>dataCons</tt>).
[_dataPathCons] :: DatatypeData -> [QName]

-- | If indexed datatype, name of the "index transport" function.
[_dataTranspIx] :: DatatypeData -> Maybe QName

-- | Transport function, should be available for all datatypes in supported
--   sorts.
[_dataTransp] :: DatatypeData -> Maybe QName
data RecordData
RecordData :: Nat -> Maybe Clause -> ConHead -> Bool -> [Dom QName] -> Telescope -> Maybe [QName] -> EtaEquality -> PatternOrCopattern -> Maybe Induction -> Maybe Bool -> IsAbstract -> CompKit -> RecordData

-- | Number of parameters.
[_recPars] :: RecordData -> Nat

-- | Was this record type created by a module application? If yes, the
--   clause is its definition (linking back to the original record type).
[_recClause] :: RecordData -> Maybe Clause

-- | Constructor name and fields.
[_recConHead] :: RecordData -> ConHead

-- | Does this record have a <tt>constructor</tt>?
[_recNamedCon] :: RecordData -> Bool

-- | The record field names.
[_recFields] :: RecordData -> [Dom QName]

-- | The record field telescope. (Includes record parameters.) Note:
--   <tt>TelV recTel _ == telView' recConType</tt>. Thus, <tt>recTel</tt>
--   is redundant.
[_recTel] :: RecordData -> Telescope

-- | Mutually recursive functions, <tt>data</tt>s and <tt>record</tt>s.
--   Does include this record. Empty if not recursive. <tt>Nothing</tt> if
--   not yet computed (by positivity checker).
[_recMutual] :: RecordData -> Maybe [QName]

-- | Eta-expand at this record type? <tt>False</tt> for unguarded recursive
--   records and coinductive records unless the user specifies otherwise.
[_recEtaEquality'] :: RecordData -> EtaEquality

-- | In case eta-equality is off, do we allow pattern matching on the
--   constructor or construction by copattern matching? Having both loses
--   subject reduction, see issue #4560. After positivity checking, this
--   field is obsolete, part of <a>EtaEquality</a>.
[_recPatternMatching] :: RecordData -> PatternOrCopattern

-- | <a>Inductive</a> or <a>CoInductive</a>? Matters only for recursive
--   records. <a>Nothing</a> means that the user did not specify it, which
--   is an error for recursive records.
[_recInduction] :: RecordData -> Maybe Induction

-- | 'Just True' means that unfolding of the recursive record terminates,
--   'Just False' means that we have no evidence for termination, and
--   <a>Nothing</a> means we have not run the termination checker yet.
[_recTerminates] :: RecordData -> Maybe Bool
[_recAbstr] :: RecordData -> IsAbstract
[_recComp] :: RecordData -> CompKit
data ConstructorData
ConstructorData :: Int -> Int -> ConHead -> QName -> IsAbstract -> CompKit -> Maybe [QName] -> [IsForced] -> Maybe [Bool] -> !Bool -> !Bool -> ConstructorData

-- | Number of parameters.
[_conPars] :: ConstructorData -> Int

-- | Number of arguments (excluding parameters).
[_conArity] :: ConstructorData -> Int

-- | Name of (original) constructor and fields. (This might be in a module
--   instance.)
[_conSrcCon] :: ConstructorData -> ConHead

-- | Name of datatype or record type.
[_conData] :: ConstructorData -> QName
[_conAbstr] :: ConstructorData -> IsAbstract

-- | Cubical composition.
[_conComp] :: ConstructorData -> CompKit

-- | Projections. <a>Nothing</a> if not yet computed.
[_conProj] :: ConstructorData -> Maybe [QName]

-- | Which arguments are forced (i.e. determined by the type of the
--   constructor)? Either this list is empty (if the forcing analysis isn't
--   run), or its length is <tt>conArity</tt>.
[_conForced] :: ConstructorData -> [IsForced]

-- | Which arguments are erased at runtime (computed during compilation to
--   treeless)? <a>True</a> means erased, <a>False</a> means retained.
--   <a>Nothing</a> if no erasure analysis has been performed yet. The
--   length of the list is <tt>conArity</tt>.
[_conErased] :: ConstructorData -> Maybe [Bool]

-- | Was <tt>--erasure</tt> in effect when the constructor was defined?
--   (This can affect the constructor's type.)
[_conErasure] :: ConstructorData -> !Bool

-- | Shall we translate the constructor on the root of the rhs into
--   copattern matching on the lhs? Activated by INLINE pragma.
[_conInline] :: ConstructorData -> !Bool
data PrimitiveData
PrimitiveData :: IsAbstract -> PrimitiveId -> [Clause] -> FunctionInverse -> Maybe CompiledClauses -> IsOpaque -> PrimitiveData
[_primAbstr] :: PrimitiveData -> IsAbstract
[_primName] :: PrimitiveData -> PrimitiveId

-- | <a>null</a> for primitive functions, <tt>not null</tt> for builtin
--   functions.
[_primClauses] :: PrimitiveData -> [Clause]

-- | Builtin functions can have inverses. For instance, natural number
--   addition.
[_primInv] :: PrimitiveData -> FunctionInverse

-- | <a>Nothing</a> for primitive functions, <tt><a>Just</a> something</tt>
--   for builtin functions.
[_primCompiled] :: PrimitiveData -> Maybe CompiledClauses

-- | Primitives can also live in opaque blocks.
[_primOpaque] :: PrimitiveData -> IsOpaque
data PrimitiveSortData
PrimitiveSortData :: BuiltinSort -> Sort -> PrimitiveSortData
[_primSortName] :: PrimitiveSortData -> BuiltinSort
[_primSortSort] :: PrimitiveSortData -> Sort

-- | Indicates the reason behind a function having not been marked
--   projection-like.
data ProjectionLikenessMissing

-- | Projection-likeness analysis has not run on this function yet. It may
--   do so in the future.
MaybeProjection :: ProjectionLikenessMissing

-- | The user has requested that this function be not be marked
--   projection-like. The analysis may already have run on this function,
--   but the results have been discarded, and it will not be run again.
NeverProjection :: ProjectionLikenessMissing
type FunctionInverse = FunctionInverse' Clause
data BuiltinSort
SortUniv :: Univ -> BuiltinSort
SortOmega :: Univ -> BuiltinSort
SortIntervalUniv :: BuiltinSort
SortLevelUniv :: BuiltinSort
data FunctionInverse' c
NotInjective :: FunctionInverse' c
Inverse :: InversionMap c -> FunctionInverse' c

-- | Did we encounter a simplifying reduction? In terms of CIC, that would
--   be a iota-reduction. In terms of Agda, this is a constructor or
--   literal pattern that matched. Just beta-reduction (substitution) or
--   delta-reduction (unfolding of definitions) does not count as
--   simplifying?
data Simplification
YesSimplification :: Simplification
NoSimplification :: Simplification

-- | Three cases: 1. not reduced, 2. reduced, but blocked, 3. reduced, not
--   blocked.
data IsReduced
NotReduced :: IsReduced
Reduced :: Blocked () -> IsReduced
data MaybeReduced a
MaybeRed :: IsReduced -> a -> MaybeReduced a
[isReduced] :: MaybeReduced a -> IsReduced
[ignoreReduced] :: MaybeReduced a -> a
type MaybeReducedArgs = [MaybeReduced (Arg Term)]
type MaybeReducedElims = [MaybeReduced Elim]

-- | Controlling <tt>reduce</tt>.
data AllowedReduction

-- | (Projection and) projection-like functions may be reduced.
ProjectionReductions :: AllowedReduction

-- | Functions marked INLINE may be reduced.
InlineReductions :: AllowedReduction

-- | Copattern definitions may be reduced.
CopatternReductions :: AllowedReduction

-- | Non-recursive functions and primitives may be reduced.
FunctionReductions :: AllowedReduction

-- | Even recursive functions may be reduced.
RecursiveReductions :: AllowedReduction

-- | Reduce <tt><a>Term</a></tt> terms.
LevelReductions :: AllowedReduction

-- | Allow <tt>allReductions</tt> in types, even if not allowed at term
--   level (used by confluence checker)
TypeLevelReductions :: AllowedReduction

-- | Functions whose termination has not (yet) been confirmed.
UnconfirmedReductions :: AllowedReduction

-- | Functions that have failed termination checking.
NonTerminatingReductions :: AllowedReduction
type AllowedReductions = SmallSet AllowedReduction
data ReduceDefs
OnlyReduceDefs :: Set QName -> ReduceDefs
DontReduceDefs :: Set QName -> ReduceDefs

-- | Primitives
data PrimitiveImpl
PrimImpl :: Type -> PrimFun -> PrimitiveImpl
type InversionMap c = Map TermHead [c]
data TermHead
SortHead :: TermHead
PiHead :: TermHead
ConsHead :: QName -> TermHead
VarHead :: Nat -> TermHead
UnknownHead :: TermHead
data BuiltinDescriptor
BuiltinData :: TCM Type -> [BuiltinId] -> BuiltinDescriptor
BuiltinDataCons :: TCM Type -> BuiltinDescriptor
BuiltinPrim :: PrimitiveId -> (Term -> TCM ()) -> BuiltinDescriptor
BuiltinSort :: BuiltinSort -> BuiltinDescriptor
BuiltinPostulate :: Relevance -> TCM Type -> BuiltinDescriptor

-- | Builtin of any kind. Type can be checked (<tt>Just t</tt>) or inferred
--   (<tt>Nothing</tt>). The second argument is the hook for the
--   verification function.
BuiltinUnknown :: Maybe (TCM Type) -> (Term -> Type -> TCM ()) -> BuiltinDescriptor
data BuiltinInfo
BuiltinInfo :: BuiltinId -> BuiltinDescriptor -> BuiltinInfo
[builtinName] :: BuiltinInfo -> BuiltinId
[builtinDesc] :: BuiltinInfo -> BuiltinDescriptor
type LetBindings = Map Name (Open LetBinding)
data AbstractMode

-- | Abstract things in the current module can be accessed.
AbstractMode :: AbstractMode

-- | No abstract things can be accessed.
ConcreteMode :: AbstractMode

-- | All abstract things can be accessed.
IgnoreAbstractMode :: AbstractMode
data UnquoteFlags
UnquoteFlags :: Bool -> UnquoteFlags
[_unquoteNormalise] :: UnquoteFlags -> Bool
data CandidateKind
LocalCandidate :: CandidateKind
GlobalCandidate :: QName -> CandidateKind

-- | Information about a mutual block which did not pass the termination
--   checker.
data TerminationError
TerminationError :: [QName] -> [CallInfo] -> TerminationError

-- | The functions which failed to check. (May not include automatically
--   generated functions.)
[termErrFunctions] :: TerminationError -> [QName]

-- | The problematic call sites.
[termErrCalls] :: TerminationError -> [CallInfo]
data IllegalRewriteRuleReason
LHSNotDefinitionOrConstructor :: IllegalRewriteRuleReason
VariablesNotBoundByLHS :: IntSet -> IllegalRewriteRuleReason
VariablesBoundMoreThanOnce :: IntSet -> IllegalRewriteRuleReason
LHSReduces :: Term -> Term -> IllegalRewriteRuleReason
HeadSymbolIsProjection :: QName -> IllegalRewriteRuleReason
HeadSymbolIsProjectionLikeFunction :: QName -> IllegalRewriteRuleReason
HeadSymbolIsTypeConstructor :: QName -> IllegalRewriteRuleReason
HeadSymbolContainsMetas :: QName -> IllegalRewriteRuleReason
ConstructorParametersNotGeneral :: ConHead -> Args -> IllegalRewriteRuleReason
ContainsUnsolvedMetaVariables :: Set MetaId -> IllegalRewriteRuleReason
BlockedOnProblems :: Set ProblemId -> IllegalRewriteRuleReason
RequiresDefinitions :: Set QName -> IllegalRewriteRuleReason
DoesNotTargetRewriteRelation :: IllegalRewriteRuleReason
BeforeFunctionDefinition :: IllegalRewriteRuleReason
BeforeMutualFunctionDefinition :: QName -> IllegalRewriteRuleReason
DuplicateRewriteRule :: IllegalRewriteRuleReason

-- | Information about a call.
data CallInfo
CallInfo :: QName -> Closure Term -> CallInfo

-- | Target function name. (Contains its range.)
[callInfoTarget] :: CallInfo -> QName

-- | To be formatted representation of the call.
[callInfoCall] :: CallInfo -> Closure Term

-- | The reason for an <a>ErasedDatatype</a> error.
data ErasedDatatypeReason

-- | There are several constructors.
SeveralConstructors :: ErasedDatatypeReason

-- | The flag <tt>--erased-matches</tt> is not used.
NoErasedMatches :: ErasedDatatypeReason

-- | The K rule is not activated.
NoK :: ErasedDatatypeReason

-- | Error when splitting a pattern variable into possible constructor
--   patterns.
data SplitError

-- | Neither data type nor record.
NotADatatype :: Closure Type -> SplitError

-- | Type could not be sufficiently reduced.
BlockedType :: Blocker -> Closure Type -> SplitError

-- | Data type, but in erased position.
ErasedDatatype :: ErasedDatatypeReason -> Closure Type -> SplitError

-- | Split on codata not allowed. UNUSED, but keep! -- |
--   NoRecordConstructor Type -- ^ record type, but no constructor
CoinductiveDatatype :: Closure Type -> SplitError
UnificationStuck :: Maybe Blocker -> QName -> Telescope -> Args -> Args -> [UnificationFailure] -> SplitError

-- | Blocking metavariable (if any)
[cantSplitBlocker] :: SplitError -> Maybe Blocker

-- | Constructor.
[cantSplitConName] :: SplitError -> QName

-- | Context for indices.
[cantSplitTel] :: SplitError -> Telescope

-- | Inferred indices (from type of constructor).
[cantSplitConIdx] :: SplitError -> Args

-- | Expected indices (from checking pattern).
[cantSplitGivenIdx] :: SplitError -> Args

-- | Reason(s) why unification got stuck.
[cantSplitFailures] :: SplitError -> [UnificationFailure]

-- | Copattern split with a catchall
CosplitCatchall :: SplitError

-- | We do not know the target type of the clause.
CosplitNoTarget :: SplitError

-- | Target type is not a record type.
CosplitNoRecordType :: Closure Type -> SplitError
CannotCreateMissingClause :: QName -> (Telescope, [NamedArg DeBruijnPattern]) -> Doc -> Closure (Abs Type) -> SplitError
GenericSplitError :: String -> SplitError
data UnificationFailure

-- | Failed to apply injectivity to constructor of indexed datatype
UnifyIndicesNotVars :: Telescope -> Type -> Term -> Term -> Args -> UnificationFailure

-- | Can't solve equation because variable occurs in (type of) lhs
UnifyRecursiveEq :: Telescope -> Type -> Int -> Term -> UnificationFailure

-- | Can't solve reflexive equation because --without-K is enabled
UnifyReflexiveEq :: Telescope -> Type -> Term -> UnificationFailure

-- | Can't solve equation because solution modality is less "usable"
UnifyUnusableModality :: Telescope -> Type -> Int -> Term -> Modality -> UnificationFailure
data NegativeUnification
UnifyConflict :: Telescope -> Term -> Term -> NegativeUnification
UnifyCycle :: Telescope -> Int -> Term -> NegativeUnification
data UnquoteError
BadVisibility :: String -> Arg Term -> UnquoteError
ConInsteadOfDef :: QName -> String -> String -> UnquoteError
DefInsteadOfCon :: QName -> String -> String -> UnquoteError
NonCanonical :: String -> Term -> UnquoteError
BlockedOnMeta :: TCState -> Blocker -> UnquoteError
PatLamWithoutClauses :: Term -> UnquoteError
UnquotePanic :: String -> UnquoteError
type DataOrRecordE = DataOrRecord' InductionAndEta
data IncorrectTypeForRewriteRelationReason
ShouldAcceptAtLeastTwoArguments :: IncorrectTypeForRewriteRelationReason
FinalTwoArgumentsNotVisible :: IncorrectTypeForRewriteRelationReason
TypeDoesNotEndInSort :: Type -> Telescope -> IncorrectTypeForRewriteRelationReason

-- | Extra information for <a>InvalidFileName</a> error.
data InvalidFileNameReason
DoesNotCorrespondToValidModuleName :: InvalidFileNameReason
RootNameModuleNotAQualifiedModuleName :: Text -> InvalidFileNameReason
data InductionAndEta
InductionAndEta :: Maybe Induction -> EtaEquality -> InductionAndEta
[recordInduction] :: InductionAndEta -> Maybe Induction
[recordEtaEquality] :: InductionAndEta -> EtaEquality

-- | Environment of the reduce monad.
data ReduceEnv
ReduceEnv :: TCEnv -> TCState -> Maybe (MetaId -> ReduceM Bool) -> ReduceEnv

-- | Read only access to environment.
[redEnv] :: ReduceEnv -> TCEnv

-- | Read only access to state (signature, metas...).
[redSt] :: ReduceEnv -> TCState

-- | An optional predicate that is used by <tt>instantiate'</tt> and
--   <tt>instantiateFull'</tt>: meta-variables are only instantiated if
--   they satisfy this predicate.
[redPred] :: ReduceEnv -> Maybe (MetaId -> ReduceM Bool)
newtype BlockT m a
BlockT :: ExceptT Blocker m a -> BlockT m a
[unBlockT] :: BlockT m a -> ExceptT Blocker m a

-- | The trivial implementation of <a>HasBuiltins</a>, using a constant
--   <a>TCState</a>.
--   
--   This may be used instead of <a>TCMT</a>/<a>ReduceM</a> where builtins
--   must be accessed in a pure context.
newtype BuiltinAccess a
BuiltinAccess :: (TCState -> a) -> BuiltinAccess a
[unBuiltinAccess] :: BuiltinAccess a -> TCState -> a

-- | The coinductive primitives.
data CoinductionKit
CoinductionKit :: QName -> QName -> QName -> CoinductionKit
[nameOfInf] :: CoinductionKit -> QName
[nameOfSharp] :: CoinductionKit -> QName
[nameOfFlat] :: CoinductionKit -> QName

-- | Sort primitives.
data SortKit
SortKit :: (UnivSize -> Univ -> QName) -> (QName -> Maybe (UnivSize, Univ)) -> SortKit
[nameOfUniv] :: SortKit -> UnivSize -> Univ -> QName
[isNameOfUniv] :: SortKit -> QName -> Maybe (UnivSize, Univ)

-- | Revert the <a>EqualityView</a>.
--   
--   Postcondition: type is reduced.
class EqualityUnview a
equalityUnview :: EqualityUnview a => a -> Type

-- | Debug print some lines if the verbosity level for the given
--   <a>VerboseKey</a> is at least <a>VerboseLevel</a>.
--   
--   Note: In the presence of <tt>OverloadedStrings</tt>, just @<tt>
--   reportS key level "Literate string" </tt><tt> gives an </tt>Ambiguous
--   type variable<tt> error in </tt>GHC@. Use the legacy functions
--   <a>reportSLn</a> and <a>reportSDoc</a> instead then.
class ReportS a
reportS :: (ReportS a, MonadDebug m) => VerboseKey -> VerboseLevel -> a -> m ()

-- | Debug print some lines if the verbosity level for the given
--   <a>VerboseKey</a> is at least <a>VerboseLevel</a>.
--   
--   Note: In the presence of <tt>OverloadedStrings</tt>, just @<tt> traceS
--   key level "Literate string" </tt><tt> gives an </tt>Ambiguous type
--   variable<tt> error in </tt>GHC@. Use the legacy functions
--   <a>traceSLn</a> and <a>traceSDoc</a> instead then.
class TraceS a
traceS :: (TraceS a, MonadDebug m) => VerboseKey -> VerboseLevel -> a -> m c -> m c
data SpeculateResult
SpeculateAbort :: SpeculateResult
SpeculateCommit :: SpeculateResult
class (MonadTCEnv m, ReadTCState m) => MonadTrace m

-- | Record a function call in the trace.
traceCall :: MonadTrace m => Call -> m a -> m a
traceCallM :: MonadTrace m => m Call -> m a -> m a

-- | Like <a>traceCall</a>, but resets <a>envCall</a> and the current
--   ranges to the previous values in the continuation.
traceCallCPS :: MonadTrace m => Call -> ((a -> m b) -> m b) -> (a -> m b) -> m b
traceClosureCall :: MonadTrace m => Closure Call -> m a -> m a

-- | Lispify and print the given highlighting information.
printHighlightingInfo :: MonadTrace m => RemoveTokenBasedHighlighting -> HighlightingInfo -> m ()

-- | Lispify and print the given highlighting information.
printHighlightingInfo :: (MonadTrace m, MonadTrans t, MonadTrace n, t n ~ m) => RemoveTokenBasedHighlighting -> HighlightingInfo -> m ()

-- | Result of querying whether size variable <tt>i</tt> is bounded by
--   another size.
data BoundedSize

-- | yes <tt>i : Size&lt; t</tt>
BoundedLt :: Term -> BoundedSize
BoundedNo :: BoundedSize

-- | Check if a type is the <a>primSize</a> type. The argument should be
--   <tt>reduce</tt>d.
class IsSizeType a
isSizeType :: (IsSizeType a, HasOptions m, HasBuiltins m) => a -> m (Maybe BoundedSize)

-- | A useful view on sizes.
data SizeView
SizeInf :: SizeView
SizeSuc :: Term -> SizeView
OtherSize :: Term -> SizeView

-- | A de Bruijn index under some projections.
data ProjectedVar
ProjectedVar :: Int -> [(ProjOrigin, QName)] -> ProjectedVar
[pvIndex] :: ProjectedVar -> Int
[prProjs] :: ProjectedVar -> [(ProjOrigin, QName)]

-- | A deep view on sizes.
data DeepSizeView
DSizeInf :: DeepSizeView
DSizeVar :: ProjectedVar -> Offset -> DeepSizeView
DSizeMeta :: MetaId -> Elims -> Offset -> DeepSizeView
DOtherSize :: Term -> DeepSizeView
data SizeViewComparable a
NotComparable :: SizeViewComparable a
YesAbove :: DeepSizeView -> a -> SizeViewComparable a
YesBelow :: DeepSizeView -> a -> SizeViewComparable a
type SizeMaxView = List1 DeepSizeView
type SizeMaxView' = [DeepSizeView]

-- | Various specializations of <tt>addCtx</tt>.
class AddContext b
addContext :: (AddContext b, MonadAddContext m) => b -> m a -> m a
contextSize :: AddContext b => b -> Nat

-- | Wrapper to tell <a>addContext</a> not to mark names as
--   <a>TypeError</a>. Used when adding a user-provided, but already type
--   checked, telescope to the context.
newtype KeepNames a
KeepNames :: a -> KeepNames a
data ConstraintStatus
AwakeConstraint :: ConstraintStatus
SleepingConstraint :: ConstraintStatus

-- | Various classes of metavariables.
data MetaClass

-- | Meta variables of record type.
Records :: MetaClass

-- | Meta variables of "hereditarily singleton" record type.
SingletonRecords :: MetaClass

-- | Meta variables of level type, if type-in-type is activated.
Levels :: MetaClass
data KeepMetas
KeepMetas :: KeepMetas
RollBackMetas :: KeepMetas

-- | Pairs of local meta-stores.
data LocalMetaStores
LocalMetaStores :: LocalMetaStore -> LocalMetaStore -> LocalMetaStores

-- | A <tt>MetaStore</tt> containing open meta-variables.
[openMetas] :: LocalMetaStores -> LocalMetaStore

-- | A <tt>MetaStore</tt> containing instantiated meta-variables.
[solvedMetas] :: LocalMetaStores -> LocalMetaStore

-- | Check whether all metas are instantiated. Precondition: argument is a
--   meta (in some form) or a list of metas.
class IsInstantiatedMeta a
isInstantiatedMeta :: (IsInstantiatedMeta a, MonadFail m, ReadTCState m) => a -> m Bool

-- | Unfreeze a meta and its type if this is a meta again. Does not
--   unfreeze deep occurrences of meta-variables or remote meta-variables.
class UnFreezeMeta a
unfreezeMeta :: (UnFreezeMeta a, MonadMetaSolver m) => a -> m ()
pattern Function :: [Clause] -> Maybe CompiledClauses -> Maybe SplitTree -> Maybe Compiled -> [Clause] -> FunctionInverse -> Maybe [QName] -> Either ProjectionLikenessMissing Projection -> SmallSet FunctionFlag -> Maybe Bool -> Maybe ExtLamInfo -> Maybe QName -> Maybe QName -> IsOpaque -> Defn
pattern Constructor :: Int -> Int -> ConHead -> QName -> IsAbstract -> CompKit -> Maybe [QName] -> [IsForced] -> Maybe [Bool] -> Bool -> Bool -> Defn
pattern Datatype :: Nat -> Nat -> Maybe Clause -> [QName] -> Sort -> Maybe [QName] -> IsAbstract -> [QName] -> Maybe QName -> Maybe QName -> Defn
pattern Primitive :: IsAbstract -> PrimitiveId -> [Clause] -> FunctionInverse -> Maybe CompiledClauses -> IsOpaque -> Defn
pattern Record :: Nat -> Maybe Clause -> ConHead -> Bool -> [Dom QName] -> Telescope -> Maybe [QName] -> EtaEquality -> PatternOrCopattern -> Maybe Induction -> Maybe Bool -> IsAbstract -> CompKit -> Defn
pattern Axiom :: Bool -> Defn
pattern DDot :: Term -> DisplayTerm
pattern DTerm :: Term -> DisplayTerm
pattern PType :: NLPat -> NLPSort
pattern PProp :: NLPat -> NLPSort
pattern PSSet :: NLPat -> NLPSort
pattern DataOrRecSig :: Int -> Defn
pattern PrimitiveSort :: BuiltinSort -> Sort -> Defn
pattern SortProp :: BuiltinSort
pattern SortSet :: BuiltinSort
pattern SortStrictSet :: BuiltinSort
pattern SortPropOmega :: BuiltinSort
pattern SortSetOmega :: BuiltinSort
pattern SortStrictSetOmega :: BuiltinSort

-- | Get the current environment
getEnv :: TCM TCEnv
typeError :: (HasCallStack, MonadTCError m) => TypeError -> m a
internalError :: (HasCallStack, MonadTCM tcm) => String -> tcm a

-- | Returns a list of length <a>conArity</a>. If no erasure analysis has
--   been performed yet, this will be a list of <a>False</a>s.
getErasedConArgs :: HasConstInfo m => QName -> m [Bool]
getTreeless :: HasConstInfo m => QName -> m (Maybe TTerm)
runReduceM :: ReduceM a -> TCM a
__IMPOSSIBLE_VERBOSE__ :: (HasCallStack, MonadDebug m) => String -> m a

-- | Change to top (=empty) context. Resets the checkpoints.
inTopContext :: (MonadTCEnv tcm, ReadTCState tcm) => tcm a -> tcm a
withInteractionId :: (MonadDebug m, MonadFail m, ReadTCState m, MonadError TCErr m, MonadTCEnv m, MonadTrace m) => InteractionId -> m a -> m a

-- | Get the <a>Range'</a> for an interaction point.
getInteractionRange :: (MonadInteractionPoints m, MonadFail m, MonadError TCErr m) => InteractionId -> m Range

-- | Get the <a>Range'</a> for a local meta-variable.
getMetaRange :: (HasCallStack, MonadDebug m, ReadTCState m) => MetaId -> m Range
withMetaId :: (HasCallStack, MonadDebug m, MonadTCEnv m, MonadTrace m, ReadTCState m) => MetaId -> m a -> m a

-- | Gets the include directories.
--   
--   Precondition: <a>optAbsoluteIncludePaths</a> must be nonempty (i.e.
--   <a>setCommandLineOptions</a> must have run).
getIncludeDirs :: HasOptions m => m [AbsolutePath]
libToTCM :: LibM a -> TCM a

-- | Tries to convert a raw top-level module name to a top-level module
--   name.
topLevelModuleName :: RawTopLevelModuleName -> TCM TopLevelModuleName

-- | <tt>highlightAsTypeChecked rPre r m</tt> runs <tt>m</tt> and returns
--   its result. Additionally, some code may be highlighted:
--   
--   <ul>
--   <li>If <tt>r</tt> is non-empty and not a sub-range of <tt>rPre</tt>
--   (after <a>continuousPerLine</a> has been applied to both): <tt>r</tt>
--   is highlighted as being type-checked while <tt>m</tt> is running (this
--   highlighting is removed if <tt>m</tt> completes
--   <i>successfully</i>).</li>
--   <li>Otherwise: Highlighting is removed for <tt>rPre - r</tt> before
--   <tt>m</tt> runs, and if <tt>m</tt> completes successfully, then
--   <tt>rPre - r</tt> is highlighted as being type-checked.</li>
--   </ul>
highlightAsTypeChecked :: MonadTrace m => Range -> Range -> m a -> m a
initState :: TCState

-- | Sets the command line options (both persistent and pragma options are
--   updated).
--   
--   Relative include directories are made absolute with respect to the
--   current working directory. If the include directories have changed
--   then the state is reset (partly, see <a>setIncludeDirs</a>).
--   
--   An empty list of relative include directories (<tt><a>Left</a>
--   []</tt>) is interpreted as <tt>["."]</tt>.
setCommandLineOptions :: CommandLineOptions -> TCM ()

-- | Run a computation in a local scope.
withScope :: ReadTCState m => ScopeInfo -> m a -> m (a, ScopeInfo)

-- | The default <a>InteractionOutputCallback</a> function prints certain
--   things to stdout (other things generate internal errors).
defaultInteractionOutputCallback :: InteractionOutputCallback
mapTCMT :: (forall a. m a -> n a) -> TCMT m a -> TCMT n a

-- | Lookup a builtin by the string used in the <tt>BUILTIN</tt> pragma.
builtinById :: String -> Maybe BuiltinId

-- | Builtins that come without a definition in Agda syntax. These are
--   giving names to Agda internal concepts which cannot be assigned an
--   Agda type.
--   
--   An example would be a user-defined name for <tt>Set</tt>.
--   
--   {-# BUILTIN TYPE Type #-}
--   
--   The type of <tt>Type</tt> would be <tt>Type : Level → Setω</tt> which
--   is not valid Agda.
isBuiltinNoDef :: BuiltinId -> Bool

-- | Get the current scope.
getScope :: ReadTCState m => m ScopeInfo

-- | Get the current context.
getContext :: MonadTCEnv m => m Context
getBuiltinName' :: HasBuiltins m => BuiltinId -> m (Maybe QName)
builtinProp :: BuiltinId
builtinSet :: BuiltinId
builtinStrictSet :: BuiltinId
builtinPropOmega :: BuiltinId
builtinSetOmega :: BuiltinId
builtinSSetOmega :: BuiltinId

-- | Get both local and imported pattern synonyms
getAllPatternSyns :: ReadTCState m => m PatternSynDefns

-- | Sets the current range (for error messages etc.) to the range of the
--   given object, if it has a range (i.e., its range is not
--   <a>noRange</a>).
setCurrentRange :: (MonadTrace m, HasRange x) => x -> m a -> m a

-- | Outside of any opaque blocks.
notUnderOpaque :: MonadTCEnv m => m a -> m a

-- | Register an interaction point during scope checking. If there is no
--   interaction id yet, create one.
registerInteractionPoint :: forall m. MonadInteractionPoints m => Bool -> Range -> Maybe Nat -> m InteractionId
insideDotPattern :: TCM a -> TCM a
isInsideDotPattern :: TCM Bool

-- | Get the path of the currently checked file
getCurrentPath :: MonadTCEnv m => m AbsolutePath

-- | Rewrite a literal to constructor form if possible.
constructorForm :: HasBuiltins m => Term -> m Term

-- | Get type of a constant, instantiated to the current context.
typeOfConst :: (HasConstInfo m, ReadTCState m) => QName -> m Type

-- | The built-in type <tt>SIZE</tt>.
sizeType :: (HasBuiltins m, MonadTCEnv m, ReadTCState m) => m Type
isInstanceConstraint :: Constraint -> Bool
shouldPostponeInstanceSearch :: (ReadTCState m, HasOptions m) => m Bool

-- | Writes a <a>TypeCheckAction</a> to the current log, using the current
--   <a>PostScopeState</a>
writeToCurrentLog :: (MonadDebug m, MonadTCState m, ReadTCState m) => TypeCheckAction -> m ()

-- | Reads the next entry in the cached type check log, if present.
readFromCachedLog :: (MonadDebug m, MonadTCState m, ReadTCState m) => m (Maybe (TypeCheckAction, PostScopeState))

-- | Empties the "to read" CachedState. To be used when it gets invalid.
cleanCachedLog :: (MonadDebug m, MonadTCState m) => m ()

-- | Caches the current type check log. Discardes the old cache. Does
--   nothing if caching is inactive.
cacheCurrentLog :: (MonadDebug m, MonadTCState m) => m ()

-- | Makes sure that the <a>stLoadedFileCache</a> is <a>Just</a>, with a
--   clean current log. Crashes is <a>stLoadedFileCache</a> is already
--   active with a dirty log. Should be called when we start typechecking
--   the current file.
activateLoadedFileCache :: (HasOptions m, MonadDebug m, MonadTCState m) => m ()

-- | To be called before any write or restore calls.
cachingStarts :: (MonadDebug m, MonadTCState m, ReadTCState m) => m ()
areWeCaching :: ReadTCState m => m Bool

-- | Runs the action and restores the current cache at the end of it.
localCache :: (MonadTCState m, ReadTCState m) => m a -> m a

-- | Runs the action without cache and restores the current cache at the
--   end of it.
withoutCache :: (MonadTCState m, ReadTCState m) => m a -> m a
restorePostScopeState :: (MonadDebug m, MonadTCState m) => PostScopeState -> m ()
enterClosure :: (MonadTCEnv m, ReadTCState m, LensClosure c a) => c -> (a -> m b) -> m b
solvingProblem :: MonadConstraint m => ProblemId -> m a -> m a

-- | Get the name of the current module, if any.
currentModule :: MonadTCEnv m => m ModuleName
addImport :: TopLevelModuleName -> TCM ()
addImportCycleCheck :: TopLevelModuleName -> TCM a -> TCM a

-- | Assumes that the first module in the import path is the module we are
--   worried about.
checkForImportCycle :: TCM ()
dropDecodedModule :: TopLevelModuleName -> TCM ()
getDecodedModule :: TopLevelModuleName -> TCM (Maybe ModuleInfo)
getDecodedModules :: TCM DecodedModules
getImportPath :: TCM [TopLevelModuleName]
getPrettyVisitedModules :: ReadTCState m => m Doc
getVisitedModule :: ReadTCState m => TopLevelModuleName -> m (Maybe ModuleInfo)
getVisitedModules :: ReadTCState m => m VisitedModules
setDecodedModules :: DecodedModules -> TCM ()
setVisitedModules :: VisitedModules -> TCM ()
storeDecodedModule :: ModuleInfo -> TCM ()
visitModule :: ModuleInfo -> TCM ()
withImportPath :: [TopLevelModuleName] -> TCM a -> TCM a
reportSLn :: MonadDebug m => VerboseKey -> VerboseLevel -> String -> m ()

-- | Prepare parts of a parameter telescope for abstraction in constructors
--   and projections.
hideAndRelParams :: (LensHiding a, LensRelevance a) => a -> a
noMutualBlock :: TCM a -> TCM a

-- | Create an open term in the current context.
makeOpen :: (ReadTCState m, MonadTCEnv m) => a -> m (Open a)

-- | Extract the value from an open term. The checkpoint at which it was
--   created must be in scope.
getOpen :: (TermSubst a, MonadTCEnv m) => Open a -> m a

-- | Extract the value from an open term. If the checkpoint is no longer in
--   scope use the provided function to pull the object to the most recent
--   common checkpoint. The function is given the substitution from the
--   common ancestor to the checkpoint of the thing.
tryGetOpen :: (TermSubst a, ReadTCState m, MonadTCEnv m) => (Substitution -> a -> Maybe a) -> Open a -> m (Maybe a)

-- | An <a>Open</a> is closed if it has checkpoint 0.
isClosed :: Open a -> Bool
currentModuleNameHash :: ReadTCState m => m ModuleNameHash

-- | Conditionally render debug <a>Doc</a> and print it.
reportSDoc :: MonadDebug m => VerboseKey -> VerboseLevel -> TCM Doc -> m ()

-- | Sets the pragma options. Checks for unsafe combinations.
setPragmaOptions :: PragmaOptions -> TCM ()

-- | If the first argument is <tt><a>Erased</a> something</tt>, then hard
--   compile-time mode is enabled when the continuation is run.
setHardCompileTimeModeIfErased :: Erased -> TCM a -> TCM a

-- | Run a computation if a certain verbosity level is activated.
--   
--   Precondition: The level must be non-negative.
verboseS :: MonadDebug m => VerboseKey -> VerboseLevel -> m () -> m ()

-- | Resets the non-persistent part of the type checking state.
resetState :: TCM ()

-- | Increase specified counter by <tt>1</tt>.
tick :: MonadStatistics m => String -> m ()

-- | Increase specified counter by <tt>n</tt>.
tickN :: MonadStatistics m => String -> Integer -> m ()

-- | Set the specified counter to the maximum of its current value and
--   <tt>n</tt>.
tickMax :: MonadStatistics m => String -> Integer -> m ()

-- | Get the statistics.
getStatistics :: ReadTCState m => m Statistics

-- | Modify the statistics via given function.
modifyStatistics :: (Statistics -> Statistics) -> TCM ()

-- | Print the given statistics.
printStatistics :: (MonadDebug m, MonadTCEnv m, HasOptions m) => Maybe TopLevelModuleName -> Statistics -> m ()
interestingCall :: Call -> Bool
getName' :: (HasBuiltins m, IsBuiltin a) => a -> m (Maybe QName)
builtinHComp :: PrimitiveId
builtinConId :: PrimitiveId

-- | Restore <a>TCState</a> after performing subcomputation.
--   
--   In contrast to <a>localState</a>, the <a>Benchmark</a> info from the
--   subcomputation is saved.
localTCState :: TCM a -> TCM a
askR :: ReduceM ReduceEnv

-- | Apply a function if a certain verbosity level is activated.
--   
--   Precondition: The level must be non-negative.
applyWhenVerboseS :: MonadDebug m => VerboseKey -> VerboseLevel -> (m a -> m a) -> m a -> m a
defAbstract :: Definition -> IsAbstract
builtinSizeInf :: BuiltinId
getBuiltin' :: HasBuiltins m => BuiltinId -> m (Maybe Term)

-- | Modify a <a>Context</a> in a computation. Warning: does not update the
--   checkpoints. Use <tt>updateContext</tt> instead.
unsafeModifyContext :: MonadTCEnv tcm => (Context -> Context) -> tcm a -> tcm a

-- | The type of a term or sort meta-variable.
metaType :: ReadTCState m => MetaId -> m Type

-- | Apply a function <tt>f</tt> to its first argument, producing the
--   proper postfix projection if <tt>f</tt> is a projection which is not
--   irrelevant.
applyDef :: HasConstInfo m => ProjOrigin -> QName -> Arg Term -> m Term
genericError :: (HasCallStack, MonadTCError m) => String -> m a

-- | Returns the library files for a given file.
--   
--   Nothing is returned if <a>optUseLibs</a> is <a>False</a>.
--   
--   An error is raised if <a>optUseLibs</a> is <a>True</a> and a library
--   file is located too far down the directory hierarchy (see
--   <a>checkLibraryFileNotTooFarDown</a>).
getAgdaLibFiles :: AbsolutePath -> TopLevelModuleName -> TCM [AgdaLibFile]
stModuleToSource :: Lens' TCState ModuleToSource
useTC :: ReadTCState m => Lens' TCState a -> m a

-- | Get the substitution from the context at a given checkpoint to the
--   current context.
checkpointSubstitution :: MonadTCEnv tcm => CheckpointId -> tcm Substitution

-- | Lens modify for <a>Benchmark</a>.
modifyBenchmark :: (Benchmark -> Benchmark) -> TCM ()
builtinsNoDef :: [BuiltinId]
sizeBuiltins :: [BuiltinId]
builtinIntervalUniv :: BuiltinId
builtinId :: BuiltinId
builtinReflId :: BuiltinId
builtinInterval :: BuiltinId
builtinPartial :: BuiltinId
builtinPartialP :: BuiltinId
builtinIsOne :: BuiltinId
builtinSub :: BuiltinId
builtinIZero :: BuiltinId
builtinIOne :: BuiltinId
builtinLevelUniv :: BuiltinId
builtinSizeUniv :: BuiltinId
builtinSize :: BuiltinId
builtinSizeLt :: BuiltinId
builtinSizeSuc :: BuiltinId
builtinSizeMax :: BuiltinId
builtinNat :: BuiltinId
builtinSuc :: BuiltinId
builtinZero :: BuiltinId
builtinNatPlus :: BuiltinId
builtinNatMinus :: BuiltinId
builtinNatTimes :: BuiltinId
builtinNatDivSucAux :: BuiltinId
builtinNatModSucAux :: BuiltinId
builtinNatEquals :: BuiltinId
builtinNatLess :: BuiltinId
builtinInteger :: BuiltinId
builtinIntegerPos :: BuiltinId
builtinIntegerNegSuc :: BuiltinId
builtinWord64 :: BuiltinId
builtinFloat :: BuiltinId
builtinChar :: BuiltinId
builtinString :: BuiltinId
builtinUnit :: BuiltinId
builtinUnitUnit :: BuiltinId
builtinSigma :: BuiltinId
builtinBool :: BuiltinId
builtinTrue :: BuiltinId
builtinFalse :: BuiltinId
builtinList :: BuiltinId
builtinNil :: BuiltinId
builtinCons :: BuiltinId
builtinIO :: BuiltinId
builtinMaybe :: BuiltinId
builtinNothing :: BuiltinId
builtinJust :: BuiltinId
builtinPath :: BuiltinId
builtinPathP :: BuiltinId
builtinItIsOne :: BuiltinId
builtinIsOne1 :: BuiltinId
builtinIsOne2 :: BuiltinId
builtinIsOneEmpty :: BuiltinId
builtinSubIn :: BuiltinId
builtinEquiv :: BuiltinId
builtinEquivFun :: BuiltinId
builtinEquivProof :: BuiltinId
builtinTranspProof :: BuiltinId
builtinInf :: BuiltinId
builtinSharp :: BuiltinId
builtinFlat :: BuiltinId
builtinEquality :: BuiltinId
builtinRefl :: BuiltinId
builtinRewrite :: BuiltinId
builtinLevelMax :: BuiltinId
builtinLevel :: BuiltinId
builtinLevelZero :: BuiltinId
builtinLevelSuc :: BuiltinId
builtinFromNat :: BuiltinId
builtinFromNeg :: BuiltinId
builtinFromString :: BuiltinId
builtinQName :: BuiltinId
builtinAgdaSort :: BuiltinId
builtinAgdaSortSet :: BuiltinId
builtinAgdaSortLit :: BuiltinId
builtinAgdaSortProp :: BuiltinId
builtinAgdaSortPropLit :: BuiltinId
builtinAgdaSortInf :: BuiltinId
builtinAgdaSortUnsupported :: BuiltinId
builtinHiding :: BuiltinId
builtinHidden :: BuiltinId
builtinInstance :: BuiltinId
builtinVisible :: BuiltinId
builtinRelevance :: BuiltinId
builtinRelevant :: BuiltinId
builtinIrrelevant :: BuiltinId
builtinQuantity :: BuiltinId
builtinQuantity0 :: BuiltinId
builtinQuantityω :: BuiltinId
builtinModality :: BuiltinId
builtinModalityConstructor :: BuiltinId
builtinAssoc :: BuiltinId
builtinAssocLeft :: BuiltinId
builtinAssocRight :: BuiltinId
builtinAssocNon :: BuiltinId
builtinPrecedence :: BuiltinId
builtinPrecRelated :: BuiltinId
builtinPrecUnrelated :: BuiltinId
builtinFixity :: BuiltinId
builtinFixityFixity :: BuiltinId
builtinArgInfo :: BuiltinId
builtinArgArgInfo :: BuiltinId
builtinArg :: BuiltinId
builtinArgArg :: BuiltinId
builtinAbs :: BuiltinId
builtinAbsAbs :: BuiltinId
builtinAgdaTerm :: BuiltinId
builtinAgdaTermVar :: BuiltinId
builtinAgdaTermLam :: BuiltinId
builtinAgdaTermExtLam :: BuiltinId
builtinAgdaTermDef :: BuiltinId
builtinAgdaTermCon :: BuiltinId
builtinAgdaTermPi :: BuiltinId
builtinAgdaTermSort :: BuiltinId
builtinAgdaTermLit :: BuiltinId
builtinAgdaTermUnsupported :: BuiltinId
builtinAgdaTermMeta :: BuiltinId
builtinAgdaErrorPart :: BuiltinId
builtinAgdaErrorPartString :: BuiltinId
builtinAgdaErrorPartTerm :: BuiltinId
builtinAgdaErrorPartPatt :: BuiltinId
builtinAgdaErrorPartName :: BuiltinId
builtinAgdaLiteral :: BuiltinId
builtinAgdaLitNat :: BuiltinId
builtinAgdaLitWord64 :: BuiltinId
builtinAgdaLitFloat :: BuiltinId
builtinAgdaLitChar :: BuiltinId
builtinAgdaLitString :: BuiltinId
builtinAgdaLitQName :: BuiltinId
builtinAgdaLitMeta :: BuiltinId
builtinAgdaClause :: BuiltinId
builtinAgdaClauseClause :: BuiltinId
builtinAgdaClauseAbsurd :: BuiltinId
builtinAgdaPattern :: BuiltinId
builtinAgdaPatVar :: BuiltinId
builtinAgdaPatCon :: BuiltinId
builtinAgdaPatDot :: BuiltinId
builtinAgdaPatLit :: BuiltinId
builtinAgdaPatProj :: BuiltinId
builtinAgdaPatAbsurd :: BuiltinId
builtinAgdaDefinitionFunDef :: BuiltinId
builtinAgdaDefinitionDataDef :: BuiltinId
builtinAgdaDefinitionRecordDef :: BuiltinId
builtinAgdaDefinitionDataConstructor :: BuiltinId
builtinAgdaDefinitionPostulate :: BuiltinId
builtinAgdaDefinitionPrimitive :: BuiltinId
builtinAgdaDefinition :: BuiltinId
builtinAgdaMeta :: BuiltinId
builtinAgdaTCM :: BuiltinId
builtinAgdaTCMReturn :: BuiltinId
builtinAgdaTCMBind :: BuiltinId
builtinAgdaTCMUnify :: BuiltinId
builtinAgdaTCMTypeError :: BuiltinId
builtinAgdaTCMInferType :: BuiltinId
builtinAgdaTCMCheckType :: BuiltinId
builtinAgdaTCMNormalise :: BuiltinId
builtinAgdaTCMReduce :: BuiltinId
builtinAgdaTCMCatchError :: BuiltinId
builtinAgdaTCMGetContext :: BuiltinId
builtinAgdaTCMExtendContext :: BuiltinId
builtinAgdaTCMInContext :: BuiltinId
builtinAgdaTCMFreshName :: BuiltinId
builtinAgdaTCMDeclareDef :: BuiltinId
builtinAgdaTCMDeclarePostulate :: BuiltinId
builtinAgdaTCMDeclareData :: BuiltinId
builtinAgdaTCMDefineData :: BuiltinId
builtinAgdaTCMDefineFun :: BuiltinId
builtinAgdaTCMGetType :: BuiltinId
builtinAgdaTCMGetDefinition :: BuiltinId
builtinAgdaTCMQuoteTerm :: BuiltinId
builtinAgdaTCMUnquoteTerm :: BuiltinId
builtinAgdaTCMQuoteOmegaTerm :: BuiltinId
builtinAgdaTCMCommit :: BuiltinId
builtinAgdaTCMIsMacro :: BuiltinId
builtinAgdaTCMBlock :: BuiltinId
builtinAgdaBlocker :: BuiltinId
builtinAgdaBlockerAll :: BuiltinId
builtinAgdaBlockerAny :: BuiltinId
builtinAgdaBlockerMeta :: BuiltinId
builtinAgdaTCMFormatErrorParts :: BuiltinId
builtinAgdaTCMDebugPrint :: BuiltinId
builtinAgdaTCMWithNormalisation :: BuiltinId
builtinAgdaTCMWithReconstructed :: BuiltinId
builtinAgdaTCMWithExpandLast :: BuiltinId
builtinAgdaTCMWithReduceDefs :: BuiltinId
builtinAgdaTCMAskNormalisation :: BuiltinId
builtinAgdaTCMAskReconstructed :: BuiltinId
builtinAgdaTCMAskExpandLast :: BuiltinId
builtinAgdaTCMAskReduceDefs :: BuiltinId
builtinAgdaTCMNoConstraints :: BuiltinId
builtinAgdaTCMWorkOnTypes :: BuiltinId
builtinAgdaTCMRunSpeculative :: BuiltinId
builtinAgdaTCMExec :: BuiltinId
builtinAgdaTCMGetInstances :: BuiltinId
builtinAgdaTCMSolveInstances :: BuiltinId
builtinAgdaTCMPragmaForeign :: BuiltinId
builtinAgdaTCMPragmaCompile :: BuiltinId
builtinIdElim :: PrimitiveId
builtinSubOut :: PrimitiveId
builtinIMin :: PrimitiveId
builtinIMax :: PrimitiveId
builtinINeg :: PrimitiveId
builtinGlue :: PrimitiveId
builtin_glue :: PrimitiveId
builtin_unglue :: PrimitiveId
builtin_glueU :: PrimitiveId
builtin_unglueU :: PrimitiveId
builtinFaceForall :: PrimitiveId
builtinComp :: PrimitiveId
builtinPOr :: PrimitiveId
builtinTrans :: PrimitiveId
builtinDepIMin :: PrimitiveId
builtinIdFace :: PrimitiveId
builtinIdPath :: PrimitiveId
builtinLockUniv :: PrimitiveId

-- | Lookup a primitive by its identifier.
primitiveById :: String -> Maybe PrimitiveId
primConId :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIdElim :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIMin :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIMax :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primINeg :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primPartial :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primPartialP :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSubOut :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primGlue :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFaceForall :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primHComp :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNatPlus :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNatMinus :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNatTimes :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNatDivSucAux :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNatModSucAux :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNatEquality :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNatLess :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primLevelZero :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primLevelSuc :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primLevelMax :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primLockUniv :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term

-- | Look up the polarity of a definition.
getPolarity :: HasConstInfo m => QName -> m [Polarity]

-- | Find information about the (local or remote) meta-variable, if any.
--   
--   If no meta-variable is found, then the reason could be that the
--   dead-code elimination (<a>eliminateDeadCode</a>) failed to find the
--   meta-variable, perhaps because some <tt>NamesIn</tt> instance is
--   incorrectly defined.
lookupMeta :: ReadTCState m => MetaId -> m (Maybe (Either RemoteMetaVariable MetaVariable))
isLocal :: ReadTCState m => QName -> m Bool
defOpaque :: Definition -> IsOpaque

-- | Empty persistent state.
initPersistentState :: PersistentTCState

-- | An initial <a>MetaId</a>.
initialMetaId :: MetaId

-- | Empty state of type checker.
initPreScopeState :: PreScopeState
emptySignature :: Signature
initPostScopeState :: PostScopeState
stTokens :: Lens' TCState HighlightingInfo
stImports :: Lens' TCState Signature
stImportedModules :: Lens' TCState (Set TopLevelModuleName)
stVisitedModules :: Lens' TCState VisitedModules
stScope :: Lens' TCState ScopeInfo
stPatternSyns :: Lens' TCState PatternSynDefns
stPatternSynImports :: Lens' TCState PatternSynDefns
stGeneralizedVars :: Lens' TCState (Maybe (Set QName))
stPragmaOptions :: Lens' TCState PragmaOptions
stImportedBuiltins :: Lens' TCState (BuiltinThings PrimFun)
stForeignCode :: Lens' TCState (Map BackendName ForeignCodeStack)
stFreshInteractionId :: Lens' TCState InteractionId
stImportedUserWarnings :: Lens' TCState (Map QName Text)
stLocalUserWarnings :: Lens' TCState (Map QName Text)
getUserWarnings :: ReadTCState m => m (Map QName Text)
useR :: ReadTCState m => Lens' TCState a -> m a
stWarningOnImport :: Lens' TCState (Maybe Text)
stImportedPartialDefs :: Lens' TCState (Set QName)
stLocalPartialDefs :: Lens' TCState (Set QName)
getPartialDefs :: ReadTCState m => m (Set QName)
stLoadedFileCache :: Lens' TCState (Maybe LoadedFileCache)
stBackends :: Lens' TCState [Backend_boot TCM]
stProjectConfigs :: Lens' TCState (Map FilePath ProjectConfig)
stAgdaLibFiles :: Lens' TCState (Map FilePath AgdaLibFile)
stTopLevelModuleNames :: Lens' TCState (BiMap RawTopLevelModuleName ModuleNameHash)
stImportedMetaStore :: Lens' TCState RemoteMetaStore
stCopiedNames :: Lens' TCState (HashMap QName QName)
stNameCopies :: Lens' TCState (HashMap QName (HashSet QName))
stFreshNameId :: Lens' TCState NameId
stFreshOpaqueId :: Lens' TCState OpaqueId
stOpaqueBlocks :: Lens' TCState (Map OpaqueId OpaqueBlock)
stOpaqueIds :: Lens' TCState (Map QName OpaqueId)
stSyntaxInfo :: Lens' TCState HighlightingInfo
stDisambiguatedNames :: Lens' TCState DisambiguatedNames
stOpenMetaStore :: Lens' TCState LocalMetaStore
stSolvedMetaStore :: Lens' TCState LocalMetaStore
stInteractionPoints :: Lens' TCState InteractionPoints
stAwakeConstraints :: Lens' TCState Constraints
stSleepingConstraints :: Lens' TCState Constraints
stDirty :: Lens' TCState Bool
stOccursCheckDefs :: Lens' TCState (Set QName)
stSignature :: Lens' TCState Signature
stModuleCheckpoints :: Lens' TCState (Map ModuleName CheckpointId)
stImportsDisplayForms :: Lens' TCState DisplayForms
stImportedDisplayForms :: Lens' TCState DisplayForms

-- | Note that the lens is "strict".
stCurrentModule :: Lens' TCState (Maybe (ModuleName, TopLevelModuleName))
stInstanceDefs :: Lens' TCState TempInstanceTable
sigInstances :: Lens' Signature InstanceTable
stTemporaryInstances :: Lens' TCState (Set QName)
stInstanceTree :: Lens' TCState (DiscrimTree QName)
itableTree :: Lens' InstanceTable (DiscrimTree QName)
stConcreteNames :: Lens' TCState ConcreteNames
stUsedNames :: Lens' TCState (Map RawName (DList RawName))
stShadowingNames :: Lens' TCState (Map Name (DList RawName))
stStatistics :: Lens' TCState Statistics
stTCWarnings :: Lens' TCState [TCWarning]
stMutualBlocks :: Lens' TCState (Map MutualId MutualBlock)
stLocalBuiltins :: Lens' TCState (BuiltinThings PrimFun)
stFreshMetaId :: Lens' TCState MetaId
stFreshMutualId :: Lens' TCState MutualId
stFreshProblemId :: Lens' TCState ProblemId
stFreshCheckpointId :: Lens' TCState CheckpointId
stFreshInt :: Lens' TCState Int
stAreWeCaching :: Lens' TCState Bool
stPostponeInstanceSearch :: Lens' TCState Bool
stConsideringInstance :: Lens' TCState Bool
stInstantiateBlocking :: Lens' TCState Bool
stBuiltinThings :: TCState -> BuiltinThings PrimFun

-- | Union two <a>Builtin</a>s. Only defined for
--   <a>BuiltinRewriteRelations</a>.
unionBuiltin :: Builtin a -> Builtin a -> Builtin a
nextFresh :: HasFresh i => TCState -> (i, TCState)
freshName :: MonadFresh NameId m => Range -> String -> m Name
freshNoName :: MonadFresh NameId m => Range -> m Name
freshNoName_ :: MonadFresh NameId m => m Name
freshRecordName :: MonadFresh NameId m => m Name

-- | Modify a part of the state monadically, and return some result.
stateTCLensM :: MonadTCState m => Lens' TCState a -> (a -> m (r, a)) -> m r

-- | Combines the source hash and the (full) hashes of the imported
--   modules.
iFullHash :: Interface -> Hash

-- | A lens for the <a>iSignature</a> field of the <a>Interface</a> type.
intSignature :: Lens' Interface Signature
buildClosure :: (MonadTCEnv m, ReadTCState m) => a -> m (Closure a)

-- | Embed <a>Comparison</a> into <a>CompareDirection</a>.
fromCmp :: Comparison -> CompareDirection

-- | Flip the direction of comparison.
flipCmp :: CompareDirection -> CompareDirection

-- | Turn a <a>Comparison</a> function into a <a>CompareDirection</a>
--   function.
--   
--   Property: <tt>dirToCmp f (fromCmp cmp) = f cmp</tt>
dirToCmp :: (Comparison -> a -> a -> c) -> CompareDirection -> a -> a -> c

-- | Append an <a>ArgName</a> to a <a>MetaNameSuggestion</a>, for computing
--   the name suggestions of eta-expansion metas. If the
--   <a>MetaNameSuggestion</a> is empty or an underscore, the field name is
--   taken as the suggestion.
suffixNameSuggestion :: MetaNameSuggestion -> ArgName -> MetaNameSuggestion
getMetaInfo :: MetaVariable -> Closure Range
normalMetaPriority :: MetaPriority
lowMetaPriority :: MetaPriority
highMetaPriority :: MetaPriority
getMetaScope :: MetaVariable -> ScopeInfo
getMetaEnv :: MetaVariable -> TCEnv
getMetaSig :: MetaVariable -> Signature
metaFrozen :: Lens' MetaVariable Frozen
_mvInfo :: Lens' MetaVariable MetaInfo
aModeToDef :: AbstractMode -> Maybe IsAbstract
aDefToMode :: IsAbstract -> AbstractMode
sigSections :: Lens' Signature Sections
sigDefinitions :: Lens' Signature Definitions
sigRewriteRules :: Lens' Signature RewriteRuleMap
secTelescope :: Lens' Section Telescope

-- | By default, we have no display form.
defaultDisplayForm :: QName -> [LocalDisplayForm]
lensTheDef :: Lens' Definition Defn

-- | Create a definition with sensible defaults.
defaultDefn :: ArgInfo -> QName -> Type -> Language -> Defn -> Definition
noCompiledRep :: CompiledRepresentation
jsBackendName :: BackendName
ghcBackendName :: BackendName
modifySystem :: (System -> System) -> ExtLamInfo -> ExtLamInfo

-- | Building the projection function (which drops the parameters).
projDropPars :: Projection -> ProjOrigin -> Term

-- | The info of the principal (record) argument.
projArgInfo :: Projection -> ArgInfo

-- | Make sure we do not overwrite a user specification.
setEtaEquality :: EtaEquality -> HasEta -> EtaEquality
emptyCompKit :: CompKit
defaultAxiom :: Defn
constTranspAxiom :: Defn
axiomConstTransp :: Defn -> Bool
datarecPars :: Defn -> Int
funClauses :: Defn -> [Clause]
funCompiled :: Defn -> Maybe CompiledClauses
funSplitTree :: Defn -> Maybe SplitTree
funTreeless :: Defn -> Maybe Compiled
funCovering :: Defn -> [Clause]
funInv :: Defn -> FunctionInverse
funMutual :: Defn -> Maybe [QName]
funProjection :: Defn -> Either ProjectionLikenessMissing Projection
funFlags :: Defn -> SmallSet FunctionFlag
funTerminates :: Defn -> Maybe Bool
funExtLam :: Defn -> Maybe ExtLamInfo
funWith :: Defn -> Maybe QName
funIsKanOp :: Defn -> Maybe QName
funOpaque :: Defn -> IsOpaque
dataPars :: Defn -> Nat
dataIxs :: Defn -> Nat
dataClause :: Defn -> Maybe Clause
dataCons :: Defn -> [QName]
dataSort :: Defn -> Sort
dataMutual :: Defn -> Maybe [QName]
dataAbstr :: Defn -> IsAbstract
dataPathCons :: Defn -> [QName]
dataTranspIx :: Defn -> Maybe QName
dataTransp :: Defn -> Maybe QName
recPars :: Defn -> Nat
recClause :: Defn -> Maybe Clause
recConHead :: Defn -> ConHead
recNamedCon :: Defn -> Bool
recFields :: Defn -> [Dom QName]
recTel :: Defn -> Telescope
recMutual :: Defn -> Maybe [QName]
recEtaEquality' :: Defn -> EtaEquality
recPatternMatching :: Defn -> PatternOrCopattern
recInduction :: Defn -> Maybe Induction
recTerminates :: Defn -> Maybe Bool
recAbstr :: Defn -> IsAbstract
recComp :: Defn -> CompKit
conPars :: Defn -> Int
conArity :: Defn -> Int
conSrcCon :: Defn -> ConHead
conData :: Defn -> QName
conAbstr :: Defn -> IsAbstract
conComp :: Defn -> CompKit
conProj :: Defn -> Maybe [QName]
conForced :: Defn -> [IsForced]
conErased :: Defn -> Maybe [Bool]
conErasure :: Defn -> Bool
conInline :: Defn -> Bool
primAbstr :: Defn -> IsAbstract
primName :: Defn -> PrimitiveId
primClauses :: Defn -> [Clause]
primInv :: Defn -> FunctionInverse
primCompiled :: Defn -> Maybe CompiledClauses
primOpaque :: Defn -> IsOpaque
primSortName :: Defn -> BuiltinSort
primSortSort :: Defn -> Sort
lensFunction :: Lens' Defn FunctionData
lensConstructor :: Lens' Defn ConstructorData
lensRecord :: Lens' Defn RecordData
lensRecTel :: Lens' RecordData Telescope
lensRecEta :: Lens' RecordData EtaEquality

-- | Is the record type recursive?
recRecursive :: Defn -> Bool
recRecursive_ :: RecordData -> Bool
recEtaEquality :: Defn -> HasEta
_recEtaEquality :: RecordData -> HasEta

-- | A template for creating <a>Function</a> definitions, with sensible
--   defaults.
emptyFunctionData :: HasOptions m => m FunctionData
emptyFunctionData_ :: Bool -> FunctionData
emptyFunction :: HasOptions m => m Defn
emptyFunction_ :: Bool -> Defn
funFlag_ :: FunctionFlag -> Lens' FunctionData Bool
funFlag :: FunctionFlag -> Lens' Defn Bool
funStatic :: Lens' Defn Bool
funInline :: Lens' Defn Bool
funMacro :: Lens' Defn Bool
funMacro_ :: Lens' FunctionData Bool

-- | Toggle the <a>FunFirstOrder</a> flag.
funFirstOrder :: Lens' Defn Bool

-- | Toggle the <a>FunErasure</a> flag.
funErasure :: Lens' Defn Bool

-- | Toggle the <a>FunAbstract</a> flag.
funAbstract :: Lens' Defn Bool

-- | Toggle the <a>FunAbstract</a> flag.
funAbstr :: Lens' Defn IsAbstract

-- | Toggle the <a>FunAbstract</a> flag.
funAbstract_ :: Lens' FunctionData Bool

-- | Toggle the <a>FunAbstract</a> flag.
funAbstr_ :: Lens' FunctionData IsAbstract

-- | Toggle the <a>FunProj</a> flag.
funProj :: Lens' Defn Bool

-- | Toggle the <a>FunProj</a> flag.
funProj_ :: Lens' FunctionData Bool
isMacro :: Defn -> Bool

-- | Checking whether we are dealing with a function yet to be defined.
isEmptyFunction :: Defn -> Bool
isCopatternLHS :: [Clause] -> Bool
recCon :: Defn -> QName
defIsRecord :: Defn -> Bool
defIsDataOrRecord :: Defn -> Bool
defConstructors :: Defn -> [QName]
redReturn :: a -> ReduceM (Reduced a' a)

-- | Conceptually: <tt>redBind m f k = either (return . Left . f) k
--   =&lt;&lt; m</tt>
redBind :: ReduceM (Reduced a a') -> (a -> b) -> (a' -> ReduceM (Reduced b b')) -> ReduceM (Reduced b b')
notReduced :: a -> MaybeReduced a
reduced :: Blocked (Arg Term) -> MaybeReduced (Arg Term)

-- | Not quite all reductions (skip non-terminating reductions)
allReductions :: AllowedReductions
reallyAllReductions :: AllowedReductions
reduceAllDefs :: ReduceDefs
locallyReduceDefs :: MonadTCEnv m => ReduceDefs -> m a -> m a

-- | Modify the lens-indicated part of the <tt>TCEnv</tt> in a
--   subcomputation.
locallyTC :: MonadTCEnv m => Lens' TCEnv a -> (a -> a) -> m b -> m b
eReduceDefs :: Lens' TCEnv ReduceDefs
locallyReduceAllDefs :: MonadTCEnv m => m a -> m a
shouldReduceDef :: MonadTCEnv m => QName -> m Bool
asksTC :: MonadTCEnv m => (TCEnv -> a) -> m a
toReduceDefs :: (Bool, [QName]) -> ReduceDefs
fromReduceDefs :: ReduceDefs -> (Bool, [QName])
locallyReconstructed :: MonadTCEnv m => m a -> m a
eReconstructed :: Lens' TCEnv Bool
isReconstructed :: MonadTCEnv m => m Bool
primFun :: QName -> Arity -> ([Arg Term] -> ReduceM (Reduced MaybeReducedArgs Term)) -> PrimFun
defClauses :: Definition -> [Clause]
defCompiled :: Definition -> Maybe CompiledClauses
defParameters :: Definition -> Maybe Nat
defInverse :: Definition -> FunctionInverse
defCompilerPragmas :: BackendName -> Definition -> [CompilerPragma]

-- | Has the definition failed the termination checker?
defNonterminating :: Definition -> Bool

-- | Has the definition not termination checked or did the check fail?
defTerminationUnconfirmed :: Definition -> Bool
defForced :: Definition -> [IsForced]
itableCounts :: Lens' InstanceTable (Map QName Int)

-- | <tt>ifTopLevelAndHighlightingLevelIs l b m</tt> runs <tt>m</tt> when
--   we're type-checking the top-level module (or before we've started
--   doing this) and either the highlighting level is <i>at least</i>
--   <tt>l</tt> or <tt>b</tt> is <a>True</a>.
ifTopLevelAndHighlightingLevelIsOr :: MonadTCEnv tcm => HighlightingLevel -> Bool -> tcm () -> tcm ()

-- | <tt>ifTopLevelAndHighlightingLevelIs l m</tt> runs <tt>m</tt> when
--   we're type-checking the top-level module (or before we've started
--   doing this) and the highlighting level is <i>at least</i> <tt>l</tt>.
ifTopLevelAndHighlightingLevelIs :: MonadTCEnv tcm => HighlightingLevel -> tcm () -> tcm ()
initEnv :: TCEnv
defaultUnquoteFlags :: UnquoteFlags
unquoteNormalise :: Lens' UnquoteFlags Bool
eUnquoteNormalise :: Lens' TCEnv Bool
eUnquoteFlags :: Lens' TCEnv UnquoteFlags
eContext :: Lens' TCEnv Context
eLetBindings :: Lens' TCEnv LetBindings
eCurrentModule :: Lens' TCEnv ModuleName
eCurrentPath :: Lens' TCEnv (Maybe AbsolutePath)
eAnonymousModules :: Lens' TCEnv [(ModuleName, Nat)]
eImportPath :: Lens' TCEnv [TopLevelModuleName]
eMutualBlock :: Lens' TCEnv (Maybe MutualId)
eTerminationCheck :: Lens' TCEnv (TerminationCheck ())
eCoverageCheck :: Lens' TCEnv CoverageCheck
eMakeCase :: Lens' TCEnv Bool
eSolvingConstraints :: Lens' TCEnv Bool
eCheckingWhere :: Lens' TCEnv Bool
eWorkingOnTypes :: Lens' TCEnv Bool
eAssignMetas :: Lens' TCEnv Bool
eActiveProblems :: Lens' TCEnv (Set ProblemId)
eAbstractMode :: Lens' TCEnv AbstractMode
eRelevance :: Lens' TCEnv Relevance

-- | Note that this lens does not satisfy all lens laws: If hard
--   compile-time mode is enabled, then quantities other than zero are
--   replaced by <a>__IMPOSSIBLE__</a>.
eQuantity :: Lens' TCEnv Quantity
eHardCompileTimeMode :: Lens' TCEnv Bool
eSplitOnStrict :: Lens' TCEnv Bool
eDisplayFormsEnabled :: Lens' TCEnv Bool
eFoldLetBindings :: Lens' TCEnv Bool
eRange :: Lens' TCEnv Range
eHighlightingRange :: Lens' TCEnv Range
eCall :: Lens' TCEnv (Maybe (Closure Call))
eHighlightingLevel :: Lens' TCEnv HighlightingLevel
eHighlightingMethod :: Lens' TCEnv HighlightingMethod
eExpandLast :: Lens' TCEnv ExpandHidden
eExpandLastBool :: Lens' TCEnv Bool
isExpandLast :: ExpandHidden -> Bool
toExpandLast :: Bool -> ExpandHidden
eAppDef :: Lens' TCEnv (Maybe QName)
eSimplification :: Lens' TCEnv Simplification
eAllowedReductions :: Lens' TCEnv AllowedReductions
eReduceDefsPair :: Lens' TCEnv (Bool, [QName])
eInjectivityDepth :: Lens' TCEnv Int
eCompareBlocked :: Lens' TCEnv Bool
ePrintDomainFreePi :: Lens' TCEnv Bool
ePrintMetasBare :: Lens' TCEnv Bool
eInsideDotPattern :: Lens' TCEnv Bool
eInstanceDepth :: Lens' TCEnv Int
eIsDebugPrinting :: Lens' TCEnv Bool
ePrintingPatternLambdas :: Lens' TCEnv [QName]
eCallByNeed :: Lens' TCEnv Bool
eCurrentCheckpoint :: Lens' TCEnv CheckpointId
eCheckpoints :: Lens' TCEnv (Map CheckpointId Substitution)
eGeneralizeMetas :: Lens' TCEnv DoGeneralize
eGeneralizedVars :: Lens' TCEnv (Map QName GeneralizedValue)
eActiveBackendName :: Lens' TCEnv (Maybe BackendName)
eConflComputingOverlap :: Lens' TCEnv Bool
eCurrentlyElaborating :: Lens' TCEnv Bool

-- | The current modality. Note that the returned cohesion component is
--   always <a>unitCohesion</a>.
currentModality :: MonadTCEnv m => m Modality
viewTC :: MonadTCEnv m => Lens' TCEnv a -> m a
onLetBindingType :: (Dom Type -> Dom Type) -> LetBinding -> LetBinding
isDontExpandLast :: ExpandHidden -> Bool
recordFieldWarningToError :: RecordFieldWarning -> TypeError
warningName :: Warning -> WarningName
illegalRewriteWarningName :: IllegalRewriteRuleReason -> WarningName

-- | Should warnings of that type be serialized?
--   
--   Only when changes in the source code can silence or influence the
--   warning.
isSourceCodeWarning :: WarningName -> Bool
tcWarningOrigin :: TCWarning -> SrcFile
sizedTypesOption :: HasOptions m => m Bool
guardednessOption :: HasOptions m => m Bool
withoutKOption :: HasOptions m => m Bool
cubicalOption :: HasOptions m => m (Maybe Cubical)
cubicalCompatibleOption :: HasOptions m => m Bool
enableCaching :: HasOptions m => m Bool
mapRedEnv :: (TCEnv -> TCEnv) -> ReduceEnv -> ReduceEnv
mapRedSt :: (TCState -> TCState) -> ReduceEnv -> ReduceEnv
mapRedEnvSt :: (TCEnv -> TCEnv) -> (TCState -> TCState) -> ReduceEnv -> ReduceEnv
reduceEnv :: Lens' ReduceEnv TCEnv
reduceSt :: Lens' ReduceEnv TCState
unKleisli :: (a -> ReduceM b) -> ReduceM (a -> b)
onReduceEnv :: (ReduceEnv -> ReduceEnv) -> ReduceM a -> ReduceM a
fmapReduce :: (a -> b) -> ReduceM a -> ReduceM b
apReduce :: ReduceM (a -> b) -> ReduceM a -> ReduceM b
thenReduce :: ReduceM a -> ReduceM b -> ReduceM b
beforeReduce :: ReduceM a -> ReduceM b -> ReduceM a
bindReduce :: ReduceM a -> (a -> ReduceM b) -> ReduceM b
runReduceF :: (a -> ReduceM b) -> TCM (a -> b)
localR :: (ReduceEnv -> ReduceEnv) -> ReduceM a -> ReduceM a
getsTC :: ReadTCState m => (TCState -> a) -> m a

-- | A variant of <a>modifyTC</a> in which the computation is strict in the
--   new state.
modifyTC' :: MonadTCState m => (TCState -> TCState) -> m ()

-- | Overwrite the part of the <a>TCState</a> focused on by the lens.
setTCLens :: MonadTCState m => Lens' TCState a -> a -> m ()
infix 4 `setTCLens`

-- | Overwrite the part of the <a>TCState</a> focused on by the lens
--   (strictly).
setTCLens' :: MonadTCState m => Lens' TCState a -> a -> m ()

-- | Modify the part of the <a>TCState</a> focused on by the lens.
modifyTCLens :: MonadTCState m => Lens' TCState a -> (a -> a) -> m ()

-- | Modify the part of the <a>TCState</a> focused on by the lens
--   (strictly).
modifyTCLens' :: MonadTCState m => Lens' TCState a -> (a -> a) -> m ()

-- | Modify a part of the state monadically.
modifyTCLensM :: MonadTCState m => Lens' TCState a -> (a -> m a) -> m ()

-- | Modify the part of the <a>TCState</a> focused on by the lens, and
--   return some result.
stateTCLens :: MonadTCState m => Lens' TCState a -> (a -> (r, a)) -> m r
runBlocked :: Monad m => BlockT m a -> m (Either Blocker a)
pureTCM :: MonadIO m => (TCState -> TCEnv -> a) -> TCMT m a
returnTCMT :: Applicative m => a -> TCMT m a
bindTCMT :: Monad m => TCMT m a -> (a -> TCMT m b) -> TCMT m b
thenTCMT :: Applicative m => TCMT m a -> TCMT m b -> TCMT m b
fmapTCMT :: Functor m => (a -> b) -> TCMT m a -> TCMT m b
apTCMT :: Applicative m => TCMT m (a -> b) -> TCMT m a -> TCMT m b

-- | Preserve the state of the failing computation.
catchError_ :: TCM a -> (TCErr -> TCM a) -> TCM a

-- | Execute a finalizer even when an exception is thrown. Does not catch
--   any errors. In case both the regular computation and the finalizer
--   throw an exception, the one of the finalizer is propagated.
finally_ :: TCM a -> TCM b -> TCM a
typeError' :: MonadTCError m => CallStack -> TypeError -> m a

-- | Utility function for 1-arg constructed type errors. Note that the
--   <tt>HasCallStack</tt> constraint is on the *resulting* function.
locatedTypeError :: MonadTCError m => (a -> TypeError) -> HasCallStack => a -> m b
genericDocError :: (HasCallStack, MonadTCError m) => Doc -> m a
typeError'_ :: (MonadTCEnv m, ReadTCState m) => CallStack -> TypeError -> m TCErr
typeError_ :: (HasCallStack, MonadTCEnv m, ReadTCState m) => TypeError -> m TCErr

-- | Running the type checking monad (most general form).
runTCM :: MonadIO m => TCEnv -> TCState -> TCMT m a -> m (a, TCState)

-- | Running the type checking monad on toplevel (with initial state).
runTCMTop :: TCM a -> IO (Either TCErr a)
runTCMTop' :: MonadIO m => TCMT m a -> m a

-- | <a>runSafeTCM</a> runs a safe <a>TCMT</a> action (a <a>TCMT</a> action
--   which cannot fail, except that it might raise <a>IOException</a>s) in
--   the initial environment.
runSafeTCM :: TCM a -> TCState -> IO (a, TCState)

-- | Runs the given computation in a separate thread, with <i>a copy</i> of
--   the current state and environment.
--   
--   Note that Agda sometimes uses actual, mutable state. If the
--   computation given to <tt>forkTCM</tt> tries to <i>modify</i> this
--   state, then bad things can happen, because accesses are not mutually
--   exclusive. The <tt>forkTCM</tt> function has been added mainly to
--   allow the thread to <i>read</i> (a snapshot of) the current state in a
--   convenient way.
--   
--   Note also that exceptions which are raised in the thread are not
--   propagated to the parent, so the thread should not do anything
--   important.
forkTCM :: TCM a -> TCM ()

-- | Base name for patterns in telescopes
patternInTeleName :: String

-- | Base name for extended lambda patterns
extendedLambdaName :: String

-- | Check whether we have an definition from an extended lambda.
isExtendedLambdaName :: QName -> Bool

-- | Name of absurdLambda definitions.
absurdLambdaName :: String

-- | Check whether we have an definition from an absurd lambda.
isAbsurdLambdaName :: QName -> Bool

-- | Base name for generalized variable projections
generalizedFieldName :: String

-- | Check whether we have a generalized variable field
getGeneralizedFieldName :: QName -> Maybe String

-- | Restore setting for <a>ExpandLast</a> to default.
doExpandLast :: TCM a -> TCM a

-- | Modify the context whenever going from the l.h.s. (term side) of the
--   typing judgement to the r.h.s. (type side).
workOnTypes :: (MonadTCEnv m, HasOptions m, MonadDebug m) => m a -> m a

-- | Set the name of the current module.
withCurrentModule :: MonadTCEnv m => ModuleName -> m a -> m a

-- | Get the number of variables bound by anonymous modules.
getAnonymousVariables :: MonadTCEnv m => ModuleName -> m Nat

-- | Add variables bound by an anonymous module.
withAnonymousModule :: ModuleName -> Nat -> TCM a -> TCM a

-- | Set the current environment to the given
withEnv :: MonadTCEnv m => TCEnv -> m a -> m a

-- | Set highlighting level
withHighlightingLevel :: HighlightingLevel -> TCM a -> TCM a
dontExpandLast :: TCM a -> TCM a
reallyDontExpandLast :: TCM a -> TCM a

-- | If the reduced did a proper match (constructor or literal pattern),
--   then record this as simplification step.
performedSimplification :: MonadTCEnv m => m a -> m a
performedSimplification' :: MonadTCEnv m => Simplification -> m a -> m a
getSimplification :: MonadTCEnv m => m Simplification

-- | Lens for <a>AllowedReductions</a>.
updateAllowedReductions :: (AllowedReductions -> AllowedReductions) -> TCEnv -> TCEnv
modifyAllowedReductions :: MonadTCEnv m => (AllowedReductions -> AllowedReductions) -> m a -> m a
putAllowedReductions :: MonadTCEnv m => AllowedReductions -> m a -> m a

-- | Reduce <tt>Def f vs</tt> only if <tt>f</tt> is a projection.
onlyReduceProjections :: MonadTCEnv m => m a -> m a

-- | Allow all reductions except for non-terminating functions (default).
allowAllReductions :: MonadTCEnv m => m a -> m a

-- | Allow all reductions including non-terminating functions.
allowNonTerminatingReductions :: MonadTCEnv m => m a -> m a

-- | Allow all reductions when reducing types. Otherwise only allow inlined
--   functions to be unfolded.
onlyReduceTypes :: MonadTCEnv m => m a -> m a

-- | Update allowed reductions when working on types
typeLevelReductions :: MonadTCEnv m => m a -> m a

-- | Don't use call-by-need evaluation for the given computation.
callByName :: TCM a -> TCM a

-- | Don't fold let bindings when printing. This is a bit crude since it
--   disables any folding of let bindings at all. In many cases it's better
--   to use <tt>removeLetBinding</tt> before printing to drop the let
--   bindings that should not be folded.
dontFoldLetBindings :: MonadTCEnv m => m a -> m a

-- | Remove a let bound variable.
removeLetBinding :: MonadTCEnv m => Name -> m a -> m a

-- | Run a <a>BuiltinAccess</a> monad.
runBuiltinAccess :: TCState -> BuiltinAccess a -> a
litType :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => Literal -> m Type
primZero :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSuc :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNat :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primWord64 :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFloat :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primChar :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primString :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primQName :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaMeta :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
setBuiltinThings :: BuiltinThings PrimFun -> TCM ()
bindBuiltinName :: BuiltinId -> Term -> TCM ()
bindPrimitive :: PrimitiveId -> PrimFun -> TCM ()

-- | Add one (more) relation symbol to the rewrite relations.
bindBuiltinRewriteRelation :: QName -> TCM ()

-- | Get the currently registered rewrite relation symbols.
getBuiltinRewriteRelations :: (HasBuiltins m, MonadTCError m) => m (Set QName)

-- | Get the currently registered rewrite relation symbols, if any.
getBuiltinRewriteRelations' :: HasBuiltins m => m (Maybe (Set QName))
getBuiltin :: (HasBuiltins m, MonadTCError m) => BuiltinId -> m Term
getPrimitive' :: HasBuiltins m => PrimitiveId -> m (Maybe PrimFun)
getPrimitive :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => PrimitiveId -> m PrimFun
getPrimitiveTerm :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => PrimitiveId -> m Term
getPrimitiveTerm' :: HasBuiltins m => PrimitiveId -> m (Maybe Term)
getPrimitiveName' :: HasBuiltins m => PrimitiveId -> m (Maybe QName)
getTerm' :: (HasBuiltins m, IsBuiltin a) => a -> m (Maybe Term)

-- | <tt>getTerm use name</tt> looks up <tt>name</tt> as a primitive or
--   builtin, and throws an error otherwise. The <tt>use</tt> argument
--   describes how the name is used for the sake of the error message.
getTerm :: (HasBuiltins m, IsBuiltin a) => String -> a -> m Term
constructorForm' :: Applicative m => m Term -> m Term -> Term -> m Term
primInteger :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIntegerPos :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIntegerNegSuc :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primUnit :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primUnitUnit :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primBool :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primTrue :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFalse :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSigma :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primList :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNil :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primCons :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIO :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primMaybe :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primNothing :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primJust :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primPath :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primPathP :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIntervalUniv :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primInterval :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIZero :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIOne :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIsOne :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primItIsOne :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIsOne1 :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIsOne2 :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIsOneEmpty :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSub :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSubIn :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primTrans :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primId :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primEquiv :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primEquivFun :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primEquivProof :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primTranspProof :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
prim_glue :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
prim_unglue :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
prim_glueU :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
prim_unglueU :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSizeUniv :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSize :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSizeLt :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSizeSuc :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSizeInf :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSizeMax :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primInf :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSharp :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFlat :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primEquality :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primRefl :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primLevel :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primLevelUniv :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primProp :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSet :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primStrictSet :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primPropOmega :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSetOmega :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primSSetOmega :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFromNat :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFromNeg :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFromString :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primArgInfo :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primArgArgInfo :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primArg :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primArgArg :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAbs :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAbsAbs :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTerm :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermVar :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermLam :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermExtLam :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermDef :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermCon :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermPi :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermSort :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermLit :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermUnsupported :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTermMeta :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaErrorPart :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaErrorPartString :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaErrorPartTerm :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaErrorPartPatt :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaErrorPartName :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primHiding :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primHidden :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primInstance :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primVisible :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primRelevance :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primRelevant :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primIrrelevant :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primQuantity :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primQuantity0 :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primQuantityω :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primModality :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primModalityConstructor :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAssoc :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAssocLeft :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAssocRight :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAssocNon :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primPrecedence :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primPrecRelated :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primPrecUnrelated :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFixity :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primFixityFixity :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaLiteral :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaLitNat :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaLitWord64 :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaLitFloat :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaLitString :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaLitChar :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaLitQName :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaLitMeta :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaSort :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaSortSet :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaSortLit :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaSortProp :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaSortPropLit :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaSortInf :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaSortUnsupported :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaDefinition :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaDefinitionFunDef :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaDefinitionDataDef :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaDefinitionRecordDef :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaDefinitionPostulate :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaDefinitionPrimitive :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaDefinitionDataConstructor :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaClause :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaClauseClause :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaClauseAbsurd :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaPattern :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaPatCon :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaPatVar :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaPatDot :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaPatLit :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaPatProj :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaPatAbsurd :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaBlocker :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaBlockerAny :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaBlockerAll :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaBlockerMeta :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCM :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMReturn :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMBind :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMUnify :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMTypeError :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMInferType :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMCheckType :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMNormalise :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMReduce :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMCatchError :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMGetContext :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMExtendContext :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMInContext :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMFreshName :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMDeclareDef :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMDeclarePostulate :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMDeclareData :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMDefineData :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMDefineFun :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMGetType :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMGetDefinition :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMQuoteTerm :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMUnquoteTerm :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMQuoteOmegaTerm :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMCommit :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMIsMacro :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMBlock :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMFormatErrorParts :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMDebugPrint :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMWithNormalisation :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMWithReconstructed :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMWithExpandLast :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMWithReduceDefs :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMAskNormalisation :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMAskReconstructed :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMAskExpandLast :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMAskReduceDefs :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMNoConstraints :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMWorkOnTypes :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMRunSpeculative :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMExec :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMGetInstances :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMSolveInstances :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMPragmaForeign :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term
primAgdaTCMPragmaCompile :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => m Term

-- | Tries to build a <a>CoinductionKit</a>.
coinductionKit' :: TCM CoinductionKit
coinductionKit :: TCM (Maybe CoinductionKit)
mkSortKit :: QName -> QName -> QName -> QName -> QName -> QName -> SortKit

-- | Compute a <a>SortKit</a> in an environment that supports failures.
--   
--   When <tt>optLoadPrimitives</tt> is set to <a>False</a>, <a>sortKit</a>
--   is a fallible operation, so for the uses of <a>sortKit</a> in fallible
--   contexts (e.g. <a>TCMT</a>), we report a type error rather than
--   exploding.
sortKit :: (HasBuiltins m, MonadTCError m, HasOptions m) => m SortKit

-- | Compute a <a>SortKit</a> in contexts that do not support failure (e.g.
--   <tt>Reify</tt>). This should only be used when we are sure that the
--   primitive sorts have been bound, i.e. because it is "after" type
--   checking.
infallibleSortKit :: HasBuiltins m => m SortKit
getPrimName :: Term -> QName
isPrimitive :: HasBuiltins m => PrimitiveId -> QName -> m Bool
intervalSort :: Sort
intervalView' :: HasBuiltins m => m (Term -> IntervalView)
intervalView :: HasBuiltins m => Term -> m IntervalView
intervalUnview :: HasBuiltins m => IntervalView -> m Term
intervalUnview' :: HasBuiltins m => m (IntervalView -> Term)

-- | Check whether the type is actually an path (lhs ≡ rhs) and extract
--   lhs, rhs, and their type.
--   
--   Precondition: type is reduced.
pathView :: HasBuiltins m => Type -> m PathView
pathView' :: HasBuiltins m => m (Type -> PathView)

-- | Non dependent Path
idViewAsPath :: HasBuiltins m => Type -> m PathView
boldPathView :: Type -> PathView

-- | Revert the <a>PathView</a>.
--   
--   Postcondition: type is reduced.
pathUnview :: PathView -> Type
conidView' :: HasBuiltins m => m (Term -> Term -> Maybe (Arg Term, Arg Term))

-- | Get the name of the equality type.
primEqualityName :: TCM QName

-- | Check whether the type is actually an equality (lhs ≡ rhs) and extract
--   lhs, rhs, and their type.
--   
--   Precondition: type is reduced.
equalityView :: Type -> TCM EqualityView

-- | Primitives with typechecking constrants.
constrainedPrims :: [PrimitiveId]
getNameOfConstrained :: HasBuiltins m => PrimitiveId -> m (Maybe QName)

-- | Does the meta variable correspond to an interaction point?
--   
--   Time: <tt>O(log n)</tt> where <tt>n</tt> is the number of interaction
--   metas.
isInteractionMeta :: ReadTCState m => MetaId -> m (Maybe InteractionId)

-- | Generates an error message corresponding to
--   <a>SigCubicalNotErasure</a> for a given <a>QName</a>.
notSoPrettySigCubicalNotErasure :: QName -> String

-- | Unless all variables in the context are module parameters, create a
--   fresh module to capture the non-module parameters. Used when unquoting
--   to make sure generated definitions work properly.
inFreshModuleIfFreeParams :: TCM a -> TCM a

-- | Lookup a section telescope.
--   
--   If it doesn't exist, like in hierarchical top-level modules, the
--   section telescope is empty.
lookupSection :: (Functor m, ReadTCState m) => ModuleName -> m Telescope
defaultGetVerbosity :: HasOptions m => m Verbosity
defaultGetProfileOptions :: HasOptions m => m ProfileOptions
defaultIsDebugPrinting :: MonadTCEnv m => m Bool
defaultNowDebugPrinting :: MonadTCEnv m => m a -> m a

-- | Print a debug message if switched on.
displayDebugMessage :: MonadDebug m => VerboseKey -> VerboseLevel -> String -> m ()

-- | During printing, catch internal errors of kind <a>Impossible</a> and
--   print them.
catchAndPrintImpossible :: (CatchImpossible m, Monad m) => VerboseKey -> VerboseLevel -> m String -> m String

-- | Check whether a certain verbosity level is activated.
--   
--   Precondition: The level must be non-negative.
hasVerbosity :: MonadDebug m => VerboseKey -> VerboseLevel -> m Bool

-- | Conditionally println debug string. Works regardless of the debug
--   flag.
alwaysReportSLn :: MonadDebug m => VerboseKey -> VerboseLevel -> String -> m ()

-- | Debug print the result of a computation.
reportResult :: MonadDebug m => VerboseKey -> VerboseLevel -> (a -> TCM Doc) -> m a -> m a

-- | Conditionally render debug <a>Doc</a> and print it. Works regardless
--   of the debug flag.
alwaysReportSDoc :: MonadDebug m => VerboseKey -> VerboseLevel -> TCM Doc -> m ()
unlessDebugPrinting :: MonadDebug m => m () -> m ()

-- | Conditionally render debug <a>Doc</a>, print it, and then continue.
traceSDoc :: MonadDebug m => VerboseKey -> VerboseLevel -> TCM Doc -> m a -> m a
traceSLn :: MonadDebug m => VerboseKey -> VerboseLevel -> String -> m a -> m a
openVerboseBracket :: MonadDebug m => VerboseKey -> VerboseLevel -> String -> m ()
closeVerboseBracket :: MonadDebug m => VerboseKey -> VerboseLevel -> m ()
closeVerboseBracketException :: MonadDebug m => VerboseKey -> VerboseLevel -> m ()

-- | Check whether a certain verbosity level is activated (exact match).
hasExactVerbosity :: MonadDebug m => VerboseKey -> VerboseLevel -> m Bool

-- | Run a computation if a certain verbosity level is activated (exact
--   match).
whenExactVerbosity :: MonadDebug m => VerboseKey -> VerboseLevel -> m () -> m ()
__CRASH_WHEN__ :: (HasCallStack, MonadTCM m, MonadDebug m) => VerboseKey -> VerboseLevel -> m ()

-- | Check whether a certain profile option is activated.
hasProfileOption :: MonadDebug m => ProfileOption -> m Bool

-- | Run some code when the given profiling option is active.
whenProfile :: MonadDebug m => ProfileOption -> m () -> m ()

-- | Resets all of the type checking state.
--   
--   Keep only <a>Benchmark</a> and backend information.
resetAllState :: TCM ()
updatePersistentState :: (PersistentTCState -> PersistentTCState) -> TCState -> TCState

-- | Same as <a>localTCState</a> but also returns the state in which we
--   were just before reverting it.
localTCStateSaving :: TCM a -> TCM (a, TCState)

-- | Same as <a>localTCState</a> but keep all warnings.
localTCStateSavingWarnings :: TCM a -> TCM a

-- | Allow rolling back the state changes of a TCM computation.
speculateTCState :: TCM (a, SpeculateResult) -> TCM a
speculateTCState_ :: TCM SpeculateResult -> TCM ()

-- | A fresh TCM instance.
--   
--   The computation is run in a fresh state, with the exception that the
--   persistent state is preserved. If the computation changes the state,
--   then these changes are ignored, except for changes to the persistent
--   state. (Changes to the persistent state are also ignored if errors
--   other than type errors or IO exceptions are encountered.)
freshTCM :: TCM a -> TCM (Either TCErr a)
lensPersistentState :: Lens' TCState PersistentTCState
modifyPersistentState :: (PersistentTCState -> PersistentTCState) -> TCM ()

-- | Lens for <a>stAccumStatistics</a>.
lensAccumStatisticsP :: Lens' PersistentTCState Statistics
lensAccumStatistics :: Lens' TCState Statistics

-- | Set the current scope.
setScope :: ScopeInfo -> TCM ()

-- | Modify the current scope.
modifyScope :: MonadTCState m => (ScopeInfo -> ScopeInfo) -> m ()

-- | Modify the current scope without updating the inverse maps.
modifyScope_ :: MonadTCState m => (ScopeInfo -> ScopeInfo) -> m ()

-- | Get a part of the current scope.
useScope :: ReadTCState m => Lens' ScopeInfo a -> m a

-- | Run a computation in a modified scope.
locallyScope :: ReadTCState m => Lens' ScopeInfo a -> (a -> a) -> m b -> m b

-- | Same as <a>withScope</a>, but discard the scope from the computation.
withScope_ :: ReadTCState m => ScopeInfo -> m a -> m a

-- | Discard any changes to the scope by a computation.
localScope :: TCM a -> TCM a

-- | Scope error.
notInScopeError :: QName -> TCM a

-- | Debug print the scope.
printScope :: String -> Int -> String -> TCM ()
notInScopeWarning :: QName -> TCM ()
modifySignature :: MonadTCState m => (Signature -> Signature) -> m ()
modifyImportedSignature :: MonadTCState m => (Signature -> Signature) -> m ()
getSignature :: ReadTCState m => m Signature

-- | Update a possibly imported definition. Warning: changes made to
--   imported definitions (during type checking) will not persist outside
--   the current module. This function is currently used to update the
--   compiled representation of a function during compilation.
modifyGlobalDefinition :: MonadTCState m => QName -> (Definition -> Definition) -> m ()
updateDefinition :: QName -> (Definition -> Definition) -> Signature -> Signature
setSignature :: MonadTCState m => Signature -> m ()

-- | Run some computation in a different signature, restore original
--   signature.
withSignature :: (ReadTCState m, MonadTCState m) => Signature -> m a -> m a
addRewriteRulesFor :: QName -> RewriteRules -> [QName] -> Signature -> Signature
updateTheDef :: (Defn -> Defn) -> Definition -> Definition
setMatchableSymbols :: QName -> [QName] -> Signature -> Signature
updateDefCopatternLHS :: (Bool -> Bool) -> Definition -> Definition
modifyRecEta :: MonadTCState m => QName -> (EtaEquality -> EtaEquality) -> m ()
lookupDefinition :: QName -> Signature -> Maybe Definition
updateDefinitions :: (Definitions -> Definitions) -> Signature -> Signature
updateDefType :: (Type -> Type) -> Definition -> Definition
updateDefArgOccurrences :: ([Occurrence] -> [Occurrence]) -> Definition -> Definition
updateDefPolarity :: ([Polarity] -> [Polarity]) -> Definition -> Definition
updateDefCompiledRep :: (CompiledRepresentation -> CompiledRepresentation) -> Definition -> Definition
addCompilerPragma :: BackendName -> CompilerPragma -> Definition -> Definition
updateFunClauses :: ([Clause] -> [Clause]) -> Defn -> Defn
updateCovering :: ([Clause] -> [Clause]) -> Defn -> Defn
updateCompiledClauses :: (Maybe CompiledClauses -> Maybe CompiledClauses) -> Defn -> Defn
updateDefBlocked :: (Blocked_ -> Blocked_) -> Definition -> Definition

-- | Set the top-level module. This affects the global module id of freshly
--   generated names.
setTopLevelModule :: TopLevelModuleName -> TCM ()

-- | The name of the current top-level module, if any.
currentTopLevelModule :: (MonadTCEnv m, ReadTCState m) => m (Maybe TopLevelModuleName)

-- | Use a different top-level module for a computation. Used when
--   generating names for imported modules.
withTopLevelModule :: TopLevelModuleName -> TCM a -> TCM a
addForeignCode :: BackendName -> String -> TCM ()
getInteractionOutputCallback :: ReadTCState m => m InteractionOutputCallback
appInteractionOutputCallback :: Response -> TCM ()
setInteractionOutputCallback :: InteractionOutputCallback -> TCM ()
getPatternSyns :: ReadTCState m => m PatternSynDefns
setPatternSyns :: PatternSynDefns -> TCM ()

-- | Lens for <a>stPatternSyns</a>.
modifyPatternSyns :: (PatternSynDefns -> PatternSynDefns) -> TCM ()
getPatternSynImports :: ReadTCState m => m PatternSynDefns
lookupPatternSyn :: AmbiguousQName -> TCM PatternSynDefn
lookupSinglePatternSyn :: QName -> TCM PatternSynDefn

-- | Lens getter for <a>Benchmark</a> from <a>TCState</a>.
theBenchmark :: TCState -> Benchmark

-- | Lens map for <a>Benchmark</a>.
updateBenchmark :: (Benchmark -> Benchmark) -> TCState -> TCState

-- | Lens for <a>stInstanceDefs</a>.
updateInstanceDefs :: (TempInstanceTable -> TempInstanceTable) -> TCState -> TCState
modifyInstanceDefs :: (TempInstanceTable -> TempInstanceTable) -> TCM ()
getAllInstanceDefs :: TCM TempInstanceTable
getAnonInstanceDefs :: TCM (Set QName)

-- | Remove an instance from the set of unresolved instances.
clearUnknownInstance :: QName -> TCM ()

-- | Add an instance whose type is still unresolved.
addUnknownInstance :: QName -> TCM ()
getCurrentRange :: MonadTCEnv m => m Range
isSizeTypeTest :: (HasOptions m, HasBuiltins m) => m (Term -> Maybe BoundedSize)
getBuiltinSize :: HasBuiltins m => m (Maybe QName, Maybe QName)
getBuiltinDefName :: HasBuiltins m => BuiltinId -> m (Maybe QName)
isSizeNameTest :: (HasOptions m, HasBuiltins m) => m (QName -> Bool)
isSizeNameTestRaw :: (HasOptions m, HasBuiltins m) => m (QName -> Bool)

-- | Test whether OPTIONS --sized-types and whether the size built-ins are
--   defined.
haveSizedTypes :: TCM Bool

-- | Test whether the SIZELT builtin is defined.
haveSizeLt :: TCM Bool

-- | Add polarity info to a SIZE builtin.
builtinSizeHook :: BuiltinId -> QName -> Type -> TCM ()

-- | The sort of built-in types <tt>SIZE</tt> and <tt>SIZELT</tt>.
sizeSort :: Sort

-- | The type of built-in types <tt>SIZE</tt> and <tt>SIZELT</tt>.
sizeUniv :: Type

-- | The built-in type <tt>SIZE</tt> with user-given name.
sizeType_ :: QName -> Type

-- | The name of <tt>SIZESUC</tt>.
sizeSucName :: (HasBuiltins m, HasOptions m) => m (Maybe QName)
sizeSuc :: HasBuiltins m => Nat -> Term -> m Term
sizeSuc_ :: QName -> Term -> Term

-- | Transform list of terms into a term build from binary maximum.
sizeMax :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => List1 Term -> m Term

-- | Expects argument to be <tt>reduce</tt>d.
sizeView :: (HasBuiltins m, MonadTCEnv m, ReadTCState m) => Term -> m SizeView
viewProjectedVar :: Term -> Maybe ProjectedVar
unviewProjectedVar :: ProjectedVar -> Term

-- | <tt>sizeViewComparable v w</tt> checks whether <tt>v &gt;= w</tt>
--   (then <tt>Left</tt>) or <tt>v &lt;= w</tt> (then <tt>Right</tt>). If
--   uncomparable, it returns <tt>NotComparable</tt>.
sizeViewComparable :: DeepSizeView -> DeepSizeView -> SizeViewComparable ()
sizeViewSuc_ :: QName -> DeepSizeView -> DeepSizeView

-- | <tt>sizeViewPred k v</tt> decrements <tt>v</tt> by <tt>k</tt> (must be
--   possible!).
sizeViewPred :: Nat -> DeepSizeView -> DeepSizeView

-- | <tt>sizeViewOffset v</tt> returns the number of successors or Nothing
--   when infty.
sizeViewOffset :: DeepSizeView -> Maybe Offset

-- | Remove successors common to both sides.
removeSucs :: (DeepSizeView, DeepSizeView) -> (DeepSizeView, DeepSizeView)

-- | Turn a size view into a term.
unSizeView :: SizeView -> TCM Term
unDeepSizeView :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => DeepSizeView -> m Term
maxViewMax :: SizeMaxView -> SizeMaxView -> SizeMaxView

-- | <tt>maxViewCons v ws = max v ws</tt>. It only adds <tt>v</tt> to
--   <tt>ws</tt> if it is not subsumed by an element of <tt>ws</tt>.
maxViewCons :: DeepSizeView -> SizeMaxView -> SizeMaxView

-- | <tt>sizeViewComparableWithMax v ws</tt> tries to find <tt>w</tt> in
--   <tt>ws</tt> that compares with <tt>v</tt> and singles this out.
--   Precondition: <tt>v /= DSizeInv</tt>.
sizeViewComparableWithMax :: DeepSizeView -> SizeMaxView -> SizeViewComparable SizeMaxView'
maxViewSuc_ :: QName -> SizeMaxView -> SizeMaxView
unMaxView :: (HasBuiltins m, MonadError TCErr m, MonadTCEnv m, ReadTCState m) => SizeMaxView -> m Term

-- | Modify the <a>Dom'</a> part of context entries.
modifyContextInfo :: MonadTCEnv tcm => (forall e. Dom e -> Dom e) -> tcm a -> tcm a

-- | Change to top (=empty) context, but don't update the checkpoints.
--   Totally not safe!
unsafeInTopContext :: (MonadTCEnv m, ReadTCState m) => m a -> m a

-- | Delete the last <tt>n</tt> bindings from the context.
--   
--   Doesn't update checkpoints! Use <a>escapeContext</a> or `updateContext
--   rho (drop n)` instead, for an appropriate substitution <tt>rho</tt>.
unsafeEscapeContext :: MonadTCM tcm => Int -> tcm a -> tcm a

-- | Delete the last <tt>n</tt> bindings from the context. Any occurrences
--   of these variables are replaced with the given <tt>err</tt>.
escapeContext :: MonadAddContext m => Impossible -> Int -> m a -> m a

-- | Add a new checkpoint. Do not use directly!
checkpoint :: (MonadDebug tcm, MonadTCM tcm, MonadFresh CheckpointId tcm, ReadTCState tcm) => Substitution -> tcm a -> tcm a

-- | Get the current context as a <a>Telescope</a>.
getContextTelescope :: (Applicative m, MonadTCEnv m) => m Telescope

-- | Get the substitution from the context at a given checkpoint to the
--   current context.
checkpointSubstitution' :: MonadTCEnv tcm => CheckpointId -> tcm (Maybe Substitution)

-- | Get substitution <tt>Γ ⊢ ρ : Γm</tt> where <tt>Γ</tt> is the current
--   context and <tt>Γm</tt> is the module parameter telescope of module
--   <tt>m</tt>.
--   
--   Returns <tt>Nothing</tt> in case the we don't have a checkpoint for
--   <tt>m</tt>.
getModuleParameterSub :: (MonadTCEnv m, ReadTCState m) => ModuleName -> m (Maybe Substitution)

-- | Default implementation of addCtx in terms of updateContext
defaultAddCtx :: MonadAddContext m => Name -> Dom Type -> m a -> m a
withFreshName_ :: MonadAddContext m => ArgName -> (Name -> m a) -> m a

-- | Run the given TCM action, and register the given variable as being
--   shadowed by all the names with the same root that are added to the
--   context during this TCM action.
withShadowingNameTCM :: Name -> TCM b -> TCM b

-- | Add a let bound variable
defaultAddLetBinding' :: (ReadTCState m, MonadTCEnv m) => Origin -> Name -> Term -> Dom Type -> m a -> m a
addRecordNameContext :: (MonadAddContext m, MonadFresh NameId m) => Dom Type -> m b -> m b
underAbstraction' :: (Subst a, MonadAddContext m, AddContext (name, Dom Type)) => (String -> name) -> Dom Type -> Abs a -> (a -> m b) -> m b

-- | Go under an abstraction. Do not extend context in case of
--   <a>NoAbs</a>.
underAbstraction :: (Subst a, MonadAddContext m) => Dom Type -> Abs a -> (a -> m b) -> m b
underAbstractionAbs' :: (Subst a, MonadAddContext m, AddContext (name, Dom Type)) => (String -> name) -> Dom Type -> Abs a -> (a -> m b) -> m b

-- | Go under an abstraction, treating <a>NoAbs</a> as <a>Abs</a>.
underAbstractionAbs :: (Subst a, MonadAddContext m) => Dom Type -> Abs a -> (a -> m b) -> m b

-- | Go under an abstract without worrying about the type to add to the
--   context.
underAbstraction_ :: (Subst a, MonadAddContext m) => Abs a -> (a -> m b) -> m b

-- | Map a monadic function on the thing under the abstraction, adding the
--   abstracted variable to the context.
mapAbstraction :: (Subst a, Subst b, MonadAddContext m) => Dom Type -> (a -> m b) -> Abs a -> m (Abs b)
mapAbstraction_ :: (Subst a, Subst b, MonadAddContext m) => (a -> m b) -> Abs a -> m (Abs b)
getLetBindings :: MonadTCEnv tcm => tcm [(Name, LetBinding)]

-- | Add a let bound variable
addLetBinding :: MonadAddContext m => ArgInfo -> Origin -> Name -> Term -> Type -> m a -> m a

-- | Remove a let bound variable and all let bindings introduced after it.
--   For instance before printing its body to avoid folding the binding
--   itself, or using bindings defined later. Relies on the invariant that
--   names introduced later are sorted after earlier names.
removeLetBindingsFrom :: MonadTCEnv m => Name -> m a -> m a

-- | Get the size of the current context.
getContextSize :: (Applicative m, MonadTCEnv m) => m Nat

-- | Generate <tt>[var (n - 1), ..., var 0]</tt> for all declarations in
--   the context.
getContextArgs :: (Applicative m, MonadTCEnv m) => m Args

-- | Generate <tt>[var (n - 1), ..., var 0]</tt> for all declarations in
--   the context.
getContextTerms :: (Applicative m, MonadTCEnv m) => m [Term]

-- | Get the names of all declarations in the context.
getContextNames :: (Applicative m, MonadTCEnv m) => m [Name]

-- | get type of bound variable (i.e. deBruijn index)
lookupBV_ :: Nat -> Context -> Maybe ContextEntry
lookupBV' :: MonadTCEnv m => Nat -> m (Maybe ContextEntry)
lookupBV :: (MonadFail m, MonadTCEnv m) => Nat -> m (Dom (Name, Type))
domOfBV :: (Applicative m, MonadFail m, MonadTCEnv m) => Nat -> m (Dom Type)
typeOfBV :: (Applicative m, MonadFail m, MonadTCEnv m) => Nat -> m Type
nameOfBV' :: (Applicative m, MonadFail m, MonadTCEnv m) => Nat -> m (Maybe Name)
nameOfBV :: (Applicative m, MonadFail m, MonadTCEnv m) => Nat -> m Name

-- | Get the term corresponding to a named variable. If it is a lambda
--   bound variable the deBruijn index is returned and if it is a let bound
--   variable its definition is returned.
getVarInfo :: (MonadFail m, MonadTCEnv m) => Name -> m (Term, Dom Type)

-- | Internal workhorse, expects value of --experimental-irrelevance flag
--   as argument.
workOnTypes' :: MonadTCEnv m => Bool -> m a -> m a

-- | Apply the quantity to the quantity annotation of the (typing/equality)
--   judgement.
--   
--   Precondition: The quantity must not be <tt><a>Quantity1</a>
--   something</tt>.
applyQuantityToJudgement :: (MonadTCEnv tcm, LensQuantity q) => q -> tcm a -> tcm a

-- | (Conditionally) wake up irrelevant variables and make them relevant.
--   For instance, in an irrelevant function argument otherwise irrelevant
--   variables may be used, so they are awoken before type checking the
--   argument.
--   
--   Also allow the use of irrelevant definitions.
applyRelevanceToContext :: (MonadTCEnv tcm, LensRelevance r) => r -> tcm a -> tcm a

-- | (Conditionally) wake up irrelevant variables and make them relevant.
--   For instance, in an irrelevant function argument otherwise irrelevant
--   variables may be used, so they are awoken before type checking the
--   argument.
--   
--   Precondition: <tt>Relevance /= Relevant</tt>
applyRelevanceToContextOnly :: MonadTCEnv tcm => Relevance -> tcm a -> tcm a

-- | Apply relevance <tt>rel</tt> the the relevance annotation of the
--   (typing/equality) judgement. This is part of the work done when going
--   into a <tt>rel</tt>-context.
--   
--   Precondition: <tt>Relevance /= Relevant</tt>
applyRelevanceToJudgementOnly :: MonadTCEnv tcm => Relevance -> tcm a -> tcm a

-- | Like <a>applyRelevanceToContext</a>, but only act on context if
--   <tt>--irrelevant-projections</tt>. See issue #2170.
applyRelevanceToContextFunBody :: (MonadTCM tcm, LensRelevance r) => r -> tcm a -> tcm a

-- | Apply inverse composition with the given cohesion to the typing
--   context.
applyCohesionToContext :: (MonadTCEnv tcm, LensCohesion m) => m -> tcm a -> tcm a
applyCohesionToContextOnly :: MonadTCEnv tcm => Cohesion -> tcm a -> tcm a

-- | Can we split on arguments of the given cohesion?
splittableCohesion :: (HasOptions m, LensCohesion a) => a -> m Bool

-- | (Conditionally) wake up irrelevant variables and make them relevant.
--   For instance, in an irrelevant function argument otherwise irrelevant
--   variables may be used, so they are awoken before type checking the
--   argument.
--   
--   Also allow the use of irrelevant definitions.
--   
--   This function might also do something for other modalities.
applyModalityToContext :: (MonadTCEnv tcm, LensModality m) => m -> tcm a -> tcm a

-- | (Conditionally) wake up irrelevant variables and make them relevant.
--   For instance, in an irrelevant function argument otherwise irrelevant
--   variables may be used, so they are awoken before type checking the
--   argument.
--   
--   This function might also do something for other modalities, but not
--   for quantities.
--   
--   Precondition: <tt>Modality /= Relevant</tt>
applyModalityToContextOnly :: MonadTCEnv tcm => Modality -> tcm a -> tcm a

-- | Apply the relevance and quantity components of the modality to the
--   modality annotation of the (typing/equality) judgement.
--   
--   Precondition: The relevance component must not be <a>Relevant</a>.
applyModalityToJudgementOnly :: MonadTCEnv tcm => Modality -> tcm a -> tcm a

-- | Like <a>applyModalityToContext</a>, but only act on context (for
--   Relevance) if <tt>--irrelevant-projections</tt>. See issue #2170.
applyModalityToContextFunBody :: (MonadTCM tcm, LensModality r) => r -> tcm a -> tcm a

-- | Wake up irrelevant variables and make them relevant. This is used when
--   type checking terms in a hole, in which case you want to be able to
--   (for instance) infer the type of an irrelevant variable. In the course
--   of type checking an irrelevant function argument
--   <a>applyRelevanceToContext</a> is used instead, which also sets the
--   context relevance to <a>Irrelevant</a>. This is not the right thing to
--   do when type checking interactively in a hole since it also marks all
--   metas created during type checking as irrelevant (issue #2568).
--   
--   Also set the current quantity to 0.
wakeIrrelevantVars :: MonadTCEnv tcm => tcm a -> tcm a
withClosure :: (MonadTCEnv m, ReadTCState m) => Closure a -> (a -> m b) -> m (Closure b)
mapClosure :: (MonadTCEnv m, ReadTCState m) => (a -> m b) -> Closure a -> m (Closure b)
solvingProblems :: MonadConstraint m => Set ProblemId -> m a -> m a
isProblemSolved :: (MonadTCEnv m, ReadTCState m) => ProblemId -> m Bool
isProblemSolved' :: (MonadTCEnv m, ReadTCState m) => Bool -> ProblemId -> m Bool
isProblemCompletelySolved :: (MonadTCEnv m, ReadTCState m) => ProblemId -> m Bool
getAllConstraints :: ReadTCState m => m Constraints

-- | A problem is considered solved if there are no unsolved blocking
--   constraints belonging to it. There's no really good principle for what
--   constraints are blocking and which are not, but the general idea is
--   that nothing bad should happen if you assume a non-blocking constraint
--   is solvable, but it turns out it isn't. For instance, assuming an
--   equality constraint between two types that turns out to be false can
--   lead to ill typed terms in places where we don't expect them.
isBlockingConstraint :: Constraint -> Bool
getConstraintsForProblem :: ReadTCState m => ProblemId -> m Constraints

-- | Get the awake constraints
getAwakeConstraints :: ReadTCState m => m Constraints
dropConstraints :: MonadConstraint m => (ProblemConstraint -> Bool) -> m ()

-- | Takes out all constraints matching given filter. Danger! The taken
--   constraints need to be solved or put back at some point.
takeConstraints :: MonadConstraint m => (ProblemConstraint -> Bool) -> m Constraints
putConstraintsToSleep :: MonadConstraint m => (ProblemConstraint -> Bool) -> m ()
putAllConstraintsToSleep :: MonadConstraint m => m ()

-- | Suspend constraints matching the predicate during the execution of the
--   second argument. Caution: held sleeping constraints will not be woken
--   up by events that would normally trigger a wakeup call.
holdConstraints :: (ConstraintStatus -> ProblemConstraint -> Bool) -> TCM a -> TCM a
takeAwakeConstraint :: MonadConstraint m => m (Maybe ProblemConstraint)
takeAwakeConstraint' :: MonadConstraint m => (ProblemConstraint -> Bool) -> m (Maybe ProblemConstraint)
withConstraint :: MonadConstraint m => (Constraint -> m a) -> ProblemConstraint -> m a
buildProblemConstraint :: (MonadTCEnv m, ReadTCState m) => Set ProblemId -> Blocker -> Constraint -> m ProblemConstraint
buildProblemConstraint_ :: (MonadTCEnv m, ReadTCState m) => Blocker -> Constraint -> m ProblemConstraint
buildConstraint :: Blocker -> Constraint -> TCM ProblemConstraint

-- | Add new a constraint
addConstraint' :: Blocker -> Constraint -> TCM ()
addConstraintTo :: Lens' TCState Constraints -> Blocker -> Constraint -> TCM ()
addAwakeConstraint' :: Blocker -> Constraint -> TCM ()

-- | Start solving constraints
nowSolvingConstraints :: MonadTCEnv m => m a -> m a
isSolvingConstraints :: MonadTCEnv m => m Bool

-- | Add constraint if the action raises a pattern violation
catchConstraint :: MonadConstraint m => Constraint -> m () -> m ()
canDropRecursiveInstance :: (ReadTCState m, HasOptions m) => m Bool

-- | Wake constraints matching the given predicate (and aren't instance
--   constraints if <a>shouldPostponeInstanceSearch</a>).
wakeConstraints' :: MonadConstraint m => (ProblemConstraint -> WakeUp) -> m ()
mapAwakeConstraints :: (Constraints -> Constraints) -> TCState -> TCState
mapSleepingConstraints :: (Constraints -> Constraints) -> TCState -> TCState

-- | Pass the current mutual block id or create a new mutual block if we
--   are not already inside on.
inMutualBlock :: (MutualId -> TCM a) -> TCM a

-- | Set the mutual block info for a block, possibly overwriting the
--   existing one.
setMutualBlockInfo :: MutualId -> MutualInfo -> TCM ()

-- | Set the mutual block info for a block if non-existing.
insertMutualBlockInfo :: MutualId -> MutualInfo -> TCM ()

-- | Set the mutual block for a definition.
setMutualBlock :: MutualId -> QName -> TCM ()

-- | Get the current mutual block, if any, otherwise a fresh mutual block
--   is returned.
currentOrFreshMutualBlock :: TCM MutualId
lookupMutualBlock :: ReadTCState tcm => MutualId -> tcm MutualBlock

-- | Reverse lookup of a mutual block id for a name.
mutualBlockOf :: QName -> TCM MutualId

-- | Check that that you don't turn on inconsistent options. For instance,
--   if --a implies --b and you have both --a and --no-b. Only warn for
--   things that have changed compared to the old options.
checkPragmaOptionConsistency :: PragmaOptions -> PragmaOptions -> TCM ()
setCommandLineOptions' :: AbsolutePath -> CommandLineOptions -> TCM ()
setLibraryPaths :: AbsolutePath -> CommandLineOptions -> TCM CommandLineOptions

-- | Makes the given directories absolute and stores them as include
--   directories.
--   
--   If the include directories change, then the state is reset
--   (completely, except for the include directories and some other
--   things).
--   
--   An empty list is interpreted as <tt>["."]</tt>.
setIncludeDirs :: [FilePath] -> AbsolutePath -> TCM ()

-- | Returns potential library files for a file without a known top-level
--   module name.
--   
--   Once the top-level module name is known one can use
--   <a>checkLibraryFileNotTooFarDown</a> to check that the potential
--   library files were not located too far down the directory hierarchy.
--   
--   Nothing is returned if <a>optUseLibs</a> is <a>False</a>.
getAgdaLibFilesWithoutTopLevelModuleName :: AbsolutePath -> TCM [AgdaLibFile]

-- | Checks that a library file for the module <tt>A.B.C</tt> (say) in the
--   directory <tt>dir<i>A</i>B</tt> is located at least two directories
--   above the file (not in <tt>dir/A</tt> or <tt>dir<i>A</i>B</tt>).
checkLibraryFileNotTooFarDown :: TopLevelModuleName -> AgdaLibFile -> TCM ()

-- | Returns the library options for a given file.
getLibraryOptions :: AbsolutePath -> TopLevelModuleName -> TCM [OptionsPragma]
setLibraryIncludes :: CommandLineOptions -> TCM CommandLineOptions
addDefaultLibraries :: AbsolutePath -> CommandLineOptions -> TCM CommandLineOptions
addTrustedExecutables :: CommandLineOptions -> TCM CommandLineOptions

-- | Set pragma options without checking for consistency.
setOptionsFromPragma :: OptionsPragma -> TCM ()
setOptionsFromPragma' :: Bool -> OptionsPragma -> TCM ()

-- | Set pragma options and check them for consistency.
checkAndSetOptionsFromPragma :: OptionsPragma -> TCM ()

-- | Disable display forms.
enableDisplayForms :: MonadTCEnv m => m a -> m a

-- | Disable display forms.
disableDisplayForms :: MonadTCEnv m => m a -> m a

-- | Check if display forms are enabled.
displayFormsEnabled :: MonadTCEnv m => m Bool
isPropEnabled :: HasOptions m => m Bool
isLevelUniverseEnabled :: HasOptions m => m Bool
isTwoLevelEnabled :: HasOptions m => m Bool
hasUniversePolymorphism :: HasOptions m => m Bool
showImplicitArguments :: HasOptions m => m Bool
showGeneralizedArguments :: HasOptions m => m Bool
showIrrelevantArguments :: HasOptions m => m Bool
showIdentitySubstitutions :: HasOptions m => m Bool

-- | Switch on printing of implicit and irrelevant arguments. E.g. for
--   reification in with-function generation.
--   
--   Restores all <a>PragmaOptions</a> after completion. Thus, do not
--   attempt to make persistent <a>PragmaOptions</a> changes in a
--   <a>withShowAllArguments</a> bracket.
withShowAllArguments :: ReadTCState m => m a -> m a
withShowAllArguments' :: ReadTCState m => Bool -> m a -> m a

-- | Change <a>PragmaOptions</a> for a computation and restore afterwards.
withPragmaOptions :: ReadTCState m => (PragmaOptions -> PragmaOptions) -> m a -> m a
withoutPrintingGeneralization :: ReadTCState m => m a -> m a
positivityCheckEnabled :: HasOptions m => m Bool
typeInType :: HasOptions m => m Bool
etaEnabled :: HasOptions m => m Bool
maxInstanceSearchDepth :: HasOptions m => m Int
maxInversionDepth :: HasOptions m => m Int

-- | Returns the <a>Language</a> currently in effect.
getLanguage :: HasOptions m => m Language

-- | If the quantity is "erased", then hard compile-time mode is enabled
--   when the continuation is run.
--   
--   Precondition: The quantity must not be <tt><a>Quantity1</a>
--   something</tt>.
setHardCompileTimeModeIfErased' :: LensQuantity q => q -> TCM a -> TCM a

-- | Use run-time mode in the continuation unless the current mode is the
--   hard compile-time mode.
setRunTimeModeUnlessInHardCompileTimeMode :: TCM a -> TCM a

-- | Use hard compile-time mode in the continuation if the first argument
--   is <tt><a>Erased</a> something</tt>. Use run-time mode if the first
--   argument is <tt><a>NotErased</a> something</tt> and the current mode
--   is not hard compile-time mode.
setModeUnlessInHardCompileTimeMode :: Erased -> TCM a -> TCM a

-- | Warn if the user explicitly wrote @<tt>ω</tt> or @<tt>plenty</tt> but
--   the current mode is the hard compile-time mode.
warnForPlentyInHardCompileTimeMode :: Erased -> TCM ()

-- | Add a constant to the signature. Lifts the definition to top level.
addConstant :: QName -> Definition -> TCM ()

-- | A combination of <a>addConstant</a> and <a>defaultDefn</a>. The
--   <a>Language</a> does not need to be supplied.
addConstant' :: QName -> ArgInfo -> QName -> Type -> Defn -> TCM ()

-- | Set termination info of a defined function symbol.
setTerminates :: MonadTCState m => QName -> Bool -> m ()

-- | Set CompiledClauses of a defined function symbol.
setCompiledClauses :: QName -> CompiledClauses -> TCM ()

-- | Set SplitTree of a defined function symbol.
setSplitTree :: QName -> SplitTree -> TCM ()

-- | Modify the clauses of a function.
modifyFunClauses :: QName -> ([Clause] -> [Clause]) -> TCM ()

-- | Lifts clauses to the top-level and adds them to definition. Also
--   adjusts the <tt>funCopatternLHS</tt> field if necessary.
addClauses :: (MonadConstraint m, MonadTCState m) => QName -> [Clause] -> m ()
mkPragma :: String -> TCM CompilerPragma

-- | Add a compiler pragma `{-# COMPILE <a>backend</a> <a>name</a>
--   <a>text</a> #-}`
addPragma :: BackendName -> QName -> String -> TCM ()
getUniqueCompilerPragma :: BackendName -> QName -> TCM (Maybe CompilerPragma)
setFunctionFlag :: FunctionFlag -> Bool -> QName -> TCM ()
markStatic :: QName -> TCM ()
markInline :: Bool -> QName -> TCM ()
markInjective :: QName -> TCM ()
markFirstOrder :: QName -> TCM ()
unionSignatures :: [Signature] -> Signature

-- | Add a section to the signature.
--   
--   The current context will be stored as the cumulative module parameters
--   for this section.
addSection :: ModuleName -> TCM ()

-- | Get a section.
--   
--   Why Maybe? The reason is that we look up all prefixes of a module to
--   compute number of parameters, and for hierarchical top-level modules,
--   A.B.C say, A and A.B do not exist.
getSection :: (Functor m, ReadTCState m) => ModuleName -> m (Maybe Section)

-- | Sets the checkpoint for the given module to the current checkpoint.
setModuleCheckpoint :: ModuleName -> TCM ()

-- | Add display forms for a name <tt>f</tt> copied by a module
--   application. Essentially if <tt>f</tt> can reduce to
--   
--   <pre>
--   λ xs → A.B.C.f vs
--   </pre>
--   
--   by unfolding module application copies (<a>defCopy</a>), then we add a
--   display form
--   
--   <pre>
--   A.B.C.f vs ==&gt; f xs
--   </pre>
addDisplayForms :: QName -> TCM ()

-- | Number of dropped initial arguments of a projection(-like) function.
projectionArgs :: Definition -> Int

-- | Add a display form to a definition (could be in this or imported
--   signature).
addDisplayForm :: QName -> DisplayForm -> TCM ()

-- | Module application (followed by module parameter abstraction).
applySection :: ModuleName -> Telescope -> ModuleName -> Args -> ScopeCopyInfo -> TCM ()
applySection' :: ModuleName -> Telescope -> ModuleName -> Args -> ScopeCopyInfo -> TCM ()

-- | Check if a display form is looping.
hasLoopingDisplayForm :: QName -> TCM Bool
getDisplayForms :: (HasConstInfo m, ReadTCState m) => QName -> m [LocalDisplayForm]
hasDisplayForms :: (HasConstInfo m, ReadTCState m) => QName -> m Bool

-- | Find all names used (recursively) by display forms of a given name.
chaseDisplayForms :: QName -> TCM (Set QName)
canonicalName :: HasConstInfo m => QName -> m QName
sameDef :: HasConstInfo m => QName -> QName -> m (Maybe QName)

-- | Does the given constructor come from a single-constructor type?
--   
--   Precondition: The name has to refer to a constructor.
singleConstructorType :: QName -> TCM Bool

-- | Generates an error message corresponding to
--   <a>SigCubicalNotErasure</a> for a given <a>QName</a>.
prettySigCubicalNotErasure :: MonadPretty m => QName -> m Doc

-- | An eliminator for <a>SigError</a>. All constructors except for
--   <a>SigAbstract</a> are assumed to be impossible.
sigError :: (HasCallStack, MonadDebug m) => m a -> SigError -> m a

-- | The computation <a>getConstInfo</a> sometimes tweaks the returned
--   <a>Definition</a>, depending on the current <a>Language</a> and the
--   <a>Language</a> of the <a>Definition</a>. This variant of
--   <a>getConstInfo</a> does not perform any tweaks.
getOriginalConstInfo :: (ReadTCState m, HasConstInfo m) => QName -> m Definition
defaultGetRewriteRulesFor :: (ReadTCState m, MonadTCEnv m) => QName -> m RewriteRules

-- | Get the original name of the projection (the current one could be from
--   a module application).
getOriginalProjection :: HasConstInfo m => QName -> m QName

-- | Is it the name of a record projection?
isProjection :: HasConstInfo m => QName -> m (Maybe Projection)
defaultGetConstInfo :: (HasOptions m, MonadDebug m, MonadTCEnv m) => TCState -> TCEnv -> QName -> m (Either SigError Definition)

-- | Return the abstract view of a definition, <i>regardless</i> of whether
--   the definition would be treated abstractly.
alwaysMakeAbstract :: Definition -> Maybe Definition
getConInfo :: HasConstInfo m => ConHead -> m Definition

-- | Look up polarity of a definition and compose with polarity represented
--   by <a>Comparison</a>.
getPolarity' :: HasConstInfo m => Comparison -> QName -> m [Polarity]

-- | Set the polarity of a definition.
setPolarity :: (MonadTCState m, MonadDebug m) => QName -> [Polarity] -> m ()

-- | Look up the forced arguments of a definition.
getForcedArgs :: HasConstInfo m => QName -> m [IsForced]

-- | Get argument occurrence info for argument <tt>i</tt> of definition
--   <tt>d</tt> (never fails).
getArgOccurrence :: QName -> Nat -> TCM Occurrence

-- | Sets the <a>defArgOccurrences</a> for the given identifier (which
--   should already exist in the signature).
setArgOccurrences :: MonadTCState m => QName -> [Occurrence] -> m ()
modifyArgOccurrences :: MonadTCState m => QName -> ([Occurrence] -> [Occurrence]) -> m ()
setTreeless :: QName -> TTerm -> TCM ()
setCompiledArgUse :: QName -> [ArgUsage] -> TCM ()
getCompiled :: HasConstInfo m => QName -> m (Maybe Compiled)
setErasedConArgs :: QName -> [Bool] -> TCM ()
getCompiledArgUse :: HasConstInfo m => QName -> m (Maybe [ArgUsage])

-- | add data constructors to a datatype
addDataCons :: QName -> [QName] -> TCM ()

-- | Get the mutually recursive identifiers of a symbol from the signature.
getMutual :: QName -> TCM (Maybe [QName])

-- | Get the mutually recursive identifiers from a <a>Definition</a>.
getMutual_ :: Defn -> Maybe [QName]

-- | Set the mutually recursive identifiers.
--   
--   TODO: This produces data of quadratic size (which has to be processed
--   upon serialization). Presumably qs is usually short, but in some cases
--   (for instance for generated code) it may be long. It would be better
--   to assign a unique identifier to each SCC, and store the names
--   separately.
setMutual :: QName -> [QName] -> TCM ()

-- | Check whether two definitions are mutually recursive.
mutuallyRecursive :: QName -> QName -> TCM Bool

-- | A function<i>data</i>record definition is nonRecursive if it is not
--   even mutually recursive with itself.
definitelyNonRecursive_ :: Defn -> Bool

-- | Get the number of parameters to the current module.
getCurrentModuleFreeVars :: TCM Nat
getDefModule :: HasConstInfo m => QName -> m (Either SigError ModuleName)

-- | Compute the number of free variables of a defined name. This is the
--   sum of number of parameters shared with the current module and the
--   number of anonymous variables (if the name comes from a let-bound
--   module).
getDefFreeVars :: (Functor m, Applicative m, ReadTCState m, MonadTCEnv m) => QName -> m Nat
getModuleFreeVars :: (Functor m, Applicative m, MonadTCEnv m, ReadTCState m) => ModuleName -> m Nat
freeVarsToApply :: (Functor m, HasConstInfo m, HasOptions m, ReadTCState m, MonadTCEnv m, MonadDebug m) => QName -> m Args

-- | Compute the context variables to apply a definition to.
--   
--   We have to insert the module telescope of the common prefix of the
--   current module and the module where the definition comes from.
--   (Properly raised to the current context.)
--   
--   Example: <tt> module M₁ Γ where module M₁ Δ where f = ... module M₃ Θ
--   where ... M₁.M₂.f [insert Γ raised by Θ] </tt>
moduleParamsToApply :: (Functor m, Applicative m, HasOptions m, MonadTCEnv m, ReadTCState m, MonadDebug m) => ModuleName -> m Args

-- | Instantiate a closed definition with the correct part of the current
--   context.
instantiateDef :: (Functor m, HasConstInfo m, HasOptions m, ReadTCState m, MonadTCEnv m, MonadDebug m) => Definition -> m Definition
instantiateRewriteRule :: (Functor m, HasConstInfo m, HasOptions m, ReadTCState m, MonadTCEnv m, MonadDebug m) => RewriteRule -> m RewriteRule
instantiateRewriteRules :: (Functor m, HasConstInfo m, HasOptions m, ReadTCState m, MonadTCEnv m, MonadDebug m) => RewriteRules -> m RewriteRules

-- | Enter abstract mode. Abstract definition in the current module are
--   transparent.
inAbstractMode :: MonadTCEnv m => m a -> m a

-- | Not in abstract mode. All abstract definitions are opaque.
inConcreteMode :: MonadTCEnv m => m a -> m a

-- | Ignore abstract mode. All abstract definitions are transparent.
ignoreAbstractMode :: MonadTCEnv m => m a -> m a

-- | Go under the given opaque block. The unfolding set will turn opaque
--   definitions transparent.
underOpaqueId :: MonadTCEnv m => OpaqueId -> m a -> m a

-- | Enter the reducibility environment associated with a definition: The
--   environment will have the same concreteness as the name, and we will
--   be in the opaque block enclosing the name, if any.
inConcreteOrAbstractMode :: (MonadTCEnv m, HasConstInfo m) => QName -> (Definition -> m a) -> m a

-- | Get relevance of a constant.
relOfConst :: HasConstInfo m => QName -> m Relevance

-- | Get modality of a constant.
modalityOfConst :: HasConstInfo m => QName -> m Modality

-- | The number of dropped parameters for a definition. 0 except for
--   projection(-like) functions and constructors.
droppedPars :: Definition -> Int
isProjection_ :: Defn -> Maybe Projection

-- | Is it the name of a non-irrelevant record projection?
isRelevantProjection :: HasConstInfo m => QName -> m (Maybe Projection)
isRelevantProjection_ :: Definition -> Maybe Projection

-- | Is it a function marked STATIC?
isStaticFun :: Defn -> Bool

-- | Is it a function marked INLINE?
isInlineFun :: Defn -> Bool

-- | Returns <tt>True</tt> if we are dealing with a proper projection,
--   i.e., not a projection-like function nor a record field value
--   (projection applied to argument).
isProperProjection :: Defn -> Bool

-- | Check whether a definition uses copatterns.
usesCopatterns :: (HasConstInfo m, HasBuiltins m) => QName -> m Bool

-- | All possible metavariable classes.
allMetaClasses :: [MetaClass]

-- | Switch off assignment of metas.
dontAssignMetas :: (MonadTCEnv m, HasOptions m, MonadDebug m) => m a -> m a

-- | Is the meta-variable from another top-level module?
isRemoteMeta :: ReadTCState m => m (MetaId -> Bool)

-- | If another meta-variable is created, then it will get this
--   <a>MetaId</a> (unless the state is changed too much, for instance by
--   <a>setTopLevelModule</a>).
nextLocalMeta :: ReadTCState m => m MetaId

-- | Run a computation and record which new metas it created.
metasCreatedBy :: forall m a. ReadTCState m => m a -> m (a, LocalMetaStores)

-- | Find information about the given local meta-variable, if any.
lookupLocalMeta' :: ReadTCState m => MetaId -> m (Maybe MetaVariable)

-- | Find information about the given local meta-variable.
lookupLocalMeta :: (HasCallStack, MonadDebug m, ReadTCState m) => MetaId -> m MetaVariable

-- | Find the meta-variable's instantiation.
lookupMetaInstantiation :: ReadTCState m => MetaId -> m MetaInstantiation

-- | Find the meta-variable's judgement.
lookupMetaJudgement :: ReadTCState m => MetaId -> m (Judgement MetaId)

-- | Find the meta-variable's modality.
lookupMetaModality :: ReadTCState m => MetaId -> m Modality

-- | Update the information associated with a local meta-variable.
updateMetaVarTCM :: HasCallStack => MetaId -> (MetaVariable -> MetaVariable) -> TCM ()
isOpenMeta :: MetaInstantiation -> Bool

-- | Insert a new meta-variable with associated information into the local
--   meta store.
insertMetaVar :: MetaId -> MetaVariable -> TCM ()

-- | Returns the <a>MetaPriority</a> of the given local meta-variable.
getMetaPriority :: (HasCallStack, MonadDebug m, ReadTCState m) => MetaId -> m MetaPriority
isSortMeta :: ReadTCState m => MetaId -> m Bool
isSortJudgement :: Judgement a -> Bool
isSortMeta_ :: MetaVariable -> Bool

-- | If a meta variable is still open, what is its kind?
metaInstantiationToMetaKind :: MetaInstantiation -> MetaKind
getMetaType :: ReadTCState m => MetaId -> m Type

-- | Compute the context variables that a local meta-variable should be
--   applied to, accounting for pruning.
getMetaContextArgs :: MonadTCEnv m => MetaVariable -> m Args

-- | Given a local meta-variable, return the type applied to the current
--   context.
getMetaTypeInContext :: (HasBuiltins m, HasCallStack, MonadDebug m, MonadReduce m, MonadTCEnv m, ReadTCState m) => MetaId -> m Type

-- | Is it a local meta-variable that might be generalized?
isGeneralizableMeta :: (HasCallStack, MonadDebug m, ReadTCState m) => MetaId -> m DoGeneralize
isInstantiatedMeta' :: (MonadFail m, ReadTCState m) => MetaId -> m (Maybe Term)

-- | Returns all metavariables in a constraint. Slightly complicated by the
--   fact that blocked terms are represented by two meta variables. To find
--   the second one we need to look up the meta listeners for the one in
--   the UnBlock constraint. This is used for the purpose of deciding if a
--   metavariable is constrained or if it can be generalized over (see
--   Agda.TypeChecking.Generalize).
constraintMetas :: Constraint -> TCM (Set MetaId)

-- | Get the listeners for a local meta-variable.
getMetaListeners :: (HasCallStack, MonadDebug m, ReadTCState m) => MetaId -> m [Listener]

-- | Create <a>MetaInfo</a> in the current environment.
createMetaInfo :: (MonadTCEnv m, ReadTCState m) => m MetaInfo
createMetaInfo' :: (MonadTCEnv m, ReadTCState m) => RunMetaOccursCheck -> m MetaInfo
setValueMetaName :: MonadMetaSolver m => Term -> MetaNameSuggestion -> m ()
setMetaNameSuggestion :: MonadMetaSolver m => MetaId -> MetaNameSuggestion -> m ()
getMetaNameSuggestion :: (HasCallStack, MonadDebug m, ReadTCState m) => MetaId -> m MetaNameSuggestion

-- | Change the ArgInfo that will be used when generalizing over this local
--   meta-variable.
setMetaGeneralizableArgInfo :: MonadMetaSolver m => MetaId -> ArgInfo -> m ()
updateMetaVarRange :: MonadMetaSolver m => MetaId -> Range -> m ()
setMetaOccursCheck :: MonadMetaSolver m => MetaId -> RunMetaOccursCheck -> m ()

-- | Find an interaction point by <a>Range'</a> by searching the whole map.
--   Issue 3000: Don't consider solved interaction points.
--   
--   O(n): linear in the number of registered interaction points.
findInteractionPoint_ :: Range -> InteractionPoints -> Maybe InteractionId

-- | Hook up a local meta-variable to an interaction point.
connectInteractionPoint :: MonadInteractionPoints m => InteractionId -> MetaId -> m ()

-- | Mark an interaction point as solved.
removeInteractionPoint :: MonadInteractionPoints m => InteractionId -> m ()

-- | Get a list of interaction ids.
getInteractionPoints :: ReadTCState m => m [InteractionId]

-- | Get all metas that correspond to unsolved interaction ids.
getInteractionMetas :: ReadTCState m => m [MetaId]
getUniqueMetasRanges :: (HasCallStack, MonadDebug m, ReadTCState m) => [MetaId] -> m [Range]
getUnsolvedMetas :: (HasCallStack, MonadDebug m, ReadTCState m) => m [Range]
getOpenMetas :: ReadTCState m => m [MetaId]
getUnsolvedInteractionMetas :: (HasCallStack, MonadDebug m, ReadTCState m) => m [Range]

-- | Get all metas that correspond to unsolved interaction ids.
getInteractionIdsAndMetas :: ReadTCState m => m [(InteractionId, MetaId)]

-- | Get the information associated to an interaction point.
lookupInteractionPoint :: (MonadFail m, ReadTCState m, MonadError TCErr m) => InteractionId -> m InteractionPoint

-- | Get <a>MetaId</a> for an interaction point. Precondition: interaction
--   point is connected.
lookupInteractionId :: (MonadFail m, ReadTCState m, MonadError TCErr m, MonadTCEnv m) => InteractionId -> m MetaId

-- | Check whether an interaction id is already associated with a meta
--   variable.
lookupInteractionMeta :: ReadTCState m => InteractionId -> m (Maybe MetaId)
lookupInteractionMeta_ :: InteractionId -> InteractionPoints -> Maybe MetaId

-- | Generate new meta variable.
newMeta :: MonadMetaSolver m => Frozen -> MetaInfo -> MetaPriority -> Permutation -> Judgement a -> m MetaId

-- | Generate a new meta variable with some instantiation given. For
--   instance, the instantiation could be a
--   <a>PostponedTypeCheckingProblem</a>.
newMetaTCM' :: MetaInstantiation -> Frozen -> MetaInfo -> MetaPriority -> Permutation -> Judgement a -> TCM MetaId
getInteractionScope :: (MonadDebug m, MonadFail m, ReadTCState m, MonadError TCErr m, MonadTCEnv m) => InteractionId -> m ScopeInfo
withMetaInfo' :: (MonadTCEnv m, ReadTCState m, MonadTrace m) => MetaVariable -> m a -> m a
withMetaInfo :: (MonadTCEnv m, ReadTCState m, MonadTrace m) => Closure Range -> m a -> m a

-- | <tt>listenToMeta l m</tt>: register <tt>l</tt> as a listener to
--   <tt>m</tt>. This is done when the type of l is blocked by <tt>m</tt>.
listenToMeta :: MonadMetaSolver m => Listener -> MetaId -> m ()

-- | Unregister a listener.
unlistenToMeta :: MonadMetaSolver m => Listener -> MetaId -> m ()
clearMetaListeners :: MonadMetaSolver m => MetaId -> m ()

-- | Do safe eta-expansions for meta (<tt>SingletonRecords,Levels</tt>).
etaExpandMetaSafe :: MonadMetaSolver m => MetaId -> m ()

-- | Eta expand metavariables listening on the current meta.
etaExpandListeners :: MonadMetaSolver m => MetaId -> m ()

-- | Wake up a meta listener and let it do its thing
wakeupListener :: MonadMetaSolver m => Listener -> m ()
solveAwakeConstraints :: MonadConstraint m => m ()
solveAwakeConstraints' :: MonadConstraint m => Bool -> m ()

-- | Freeze the given meta-variables (but only if they are open) and return
--   those that were not already frozen.
freezeMetas :: forall m. MonadTCState m => LocalMetaStore -> m (Set MetaId)

-- | Thaw all open meta variables.
unfreezeMetas :: TCM ()
isFrozen :: (HasCallStack, MonadDebug m, ReadTCState m) => MetaId -> m Bool
withFrozenMetas :: (MonadMetaSolver m, MonadTCState m) => m a -> m a

-- | The result and associated parameters of a type-checked file, when
--   invoked directly via interaction or a backend. Note that the
--   constructor is not exported.
data CheckResult

-- | Flattened unidirectional pattern for <a>CheckResult</a> for
--   destructuring inside the <a>ModuleInfo</a> field.
pattern CheckResult :: Interface -> [TCWarning] -> ModuleCheckMode -> Source -> CheckResult
crInterface :: CheckResult -> Interface
crWarnings :: CheckResult -> [TCWarning]
crMode :: CheckResult -> ModuleCheckMode

-- | Ask the active backend whether a type may be erased. See issue #3732.
activeBackendMayEraseType :: QName -> TCM Bool
backendInteraction :: AbsolutePath -> [Backend] -> TCM () -> (AbsolutePath -> TCM CheckResult) -> TCM ()
parseBackendOptions :: [Backend] -> [String] -> CommandLineOptions -> OptM ([Backend], CommandLineOptions)

-- | Call the <a>compilerMain</a> function of the given backend.
callBackend :: String -> IsMain -> CheckResult -> TCM ()

-- | Look for a backend of the given name.
lookupBackend :: BackendName -> TCM (Maybe Backend)

-- | Get the currently active backend (if any).
activeBackend :: TCM (Maybe Backend)

module Agda.Interaction.InteractionTop
type CommandM = StateT CommandState TCM
data GiveRefine
Give :: GiveRefine
Refine :: GiveRefine
Intro :: GiveRefine
ElaborateGive :: Rewrite -> GiveRefine

-- | Put a response by the callback function given by
--   <a>stInteractionOutputCallback</a>.
putResponse :: Response -> CommandM ()

-- | Restore both <a>TCState</a> and <a>CommandState</a>.
localStateCommandM :: CommandM a -> CommandM a

-- | Computes some status information.
--   
--   Does not change the state.
status :: CommandM Status

-- | Explain why something is in scope.
whyInScope :: String -> CommandM ()

-- | Creates a command queue, and forks a thread that writes commands to
--   the queue. The queue is returned.
initialiseCommandQueue :: IO Command -> IO CommandQueue

-- | If the next command from the command queue is anything but an actual
--   command, then the command is returned.
--   
--   If the command is an <a>IOTCM</a> command, then the following happens:
--   The given computation is applied to the command and executed. If an
--   abort command is encountered (and acted upon), then the computation is
--   interrupted, the persistent state and all options are restored, and
--   some commands are sent to the frontend. If the computation was not
--   interrupted, then its result is returned.
maybeAbort :: (IOTCM -> CommandM a) -> CommandM (Command' (Maybe a))
atTopLevel :: CommandM a -> CommandM a

-- | Set <a>envCurrentPath</a> to <a>theCurrentFile</a>, if any.
withCurrentFile :: CommandM a -> CommandM a

-- | Restore <a>TCState</a>, do not touch <a>CommandState</a>.
liftLocalState :: TCM a -> CommandM a

-- | Build an opposite action to <a>lift</a> for state monads.
revLift :: MonadState st m => (forall c. m c -> st -> k (c, st)) -> (forall b. k b -> m b) -> (forall x. (m a -> k x) -> k x) -> m a
revLiftTC :: MonadTCState m => (forall c. m c -> TCState -> k (c, TCState)) -> (forall b. k b -> m b) -> (forall x. (m a -> k x) -> k x) -> m a

-- | Opposite of <a>liftIO</a> for <a>CommandM</a>.
--   
--   This function should only be applied to computations that are
--   guaranteed not to raise any errors (except for <a>IOException</a>s).
commandMToIO :: (forall x. (CommandM a -> IO x) -> IO x) -> CommandM a

-- | Lift a TCM action transformer to a CommandM action transformer.
liftCommandMT :: (forall x. TCM x -> TCM x) -> CommandM a -> CommandM a

-- | Ditto, but restore state.
liftCommandMTLocalState :: (forall x. TCM x -> TCM x) -> CommandM a -> CommandM a

-- | A Lens for <a>theInteractionPoints</a>.
modifyTheInteractionPoints :: ([InteractionId] -> [InteractionId]) -> CommandM ()

-- | A Lens for <a>oldInteractionScopes</a>.
modifyOldInteractionScopes :: (OldInteractionScopes -> OldInteractionScopes) -> CommandM ()
insertOldInteractionScope :: InteractionId -> ScopeInfo -> CommandM ()
removeOldInteractionScope :: InteractionId -> CommandM ()
getOldInteractionScope :: InteractionId -> CommandM ScopeInfo

-- | Do setup and error handling for a command.
handleCommand_ :: CommandM () -> CommandM ()
handleCommand :: (forall a. CommandM a -> CommandM a) -> CommandM () -> CommandM () -> CommandM ()

-- | Tells the Emacs mode to go to the first error position (if any).
tellEmacsToJumpToError :: Range -> [Response]

-- | Run an <a>IOTCM</a> value, catch the exceptions, emit output
--   
--   If an error happens the state of <a>CommandM</a> does not change, but
--   stPersistent may change (which contains successfully loaded interfaces
--   for example).
runInteraction :: IOTCM -> CommandM ()

-- | Can the command run even if the relevant file has not been loaded into
--   the state?
independent :: Interaction -> Bool

-- | <tt>cmd_load' file argv unsolvedOk cmd</tt> loads the module in file
--   <tt>file</tt>, using <tt>argv</tt> as the command-line options.
--   
--   If type checking completes without any exceptions having been
--   encountered then the command <tt>cmd r</tt> is executed, where
--   <tt>r</tt> is the result of <a>typeCheckMain</a>.
cmd_load' :: FilePath -> [String] -> Bool -> Mode -> (CheckResult -> CommandM a) -> CommandM a

-- | Interpret an interaction
interpret :: Interaction -> CommandM ()

-- | Should <a>Resp_InteractionPoints</a> be issued after the command has
--   run?
updateInteractionPointsAfter :: Interaction -> Bool

-- | Displays or updates status information.
--   
--   Does not change the state.
displayStatus :: CommandM ()

-- | <tt>display_info</tt> does what <tt><tt>display_info'</tt> False</tt>
--   does, but additionally displays some status information (see
--   <a>status</a> and <a>displayStatus</a>).
display_info :: DisplayInfo -> CommandM ()

-- | Shows all the top-level names in the given module, along with their
--   types.
showModuleContents :: Rewrite -> Range -> String -> CommandM ()

-- | Shows all the top-level names in scope which mention all the given
--   identifiers in their type.
searchAbout :: Rewrite -> Range -> String -> CommandM ()

-- | Solved goals already instantiated internally The second argument
--   potentially limits it to one specific goal.
solveInstantiatedGoals :: Rewrite -> Maybe InteractionId -> CommandM ()

-- | Parses and scope checks an expression (using the "inside scope" as the
--   scope), performs the given command with the expression as input, and
--   returns the result and the time it takes.
parseAndDoAtToplevel :: (Expr -> TCM a) -> String -> CommandM (Maybe CPUTime, a)

-- | Sets the command line options and updates the status information.
setCommandLineOpts :: CommandLineOptions -> CommandM ()

-- | Tell to highlight the code using the given highlighting info (unless
--   it is <tt>Nothing</tt>).
tellToUpdateHighlighting :: Maybe (HighlightingInfo, HighlightingMethod, ModuleToSource) -> IO [Response]
highlightExpr :: Expr -> TCM ()

-- | A "give"-like action (give, refine, etc).
--   
--   <tt>give_gen force ii rng s give_ref mk_newtxt</tt> acts on
--   interaction point <tt>ii</tt> occupying range <tt>rng</tt>, placing
--   the new content given by string <tt>s</tt>, and replacing <tt>ii</tt>
--   by the newly created interaction points in the state if safety checks
--   pass (unless <tt>force</tt> is applied).
give_gen :: UseForce -> InteractionId -> Range -> String -> GiveRefine -> CommandM ()
maybeTimed :: CommandM a -> CommandM (Maybe CPUTime, a)

-- | Displays the current goal, the given document, and the current
--   context.
--   
--   Should not modify the state.
cmd_goal_type_context_and :: GoalTypeAux -> Rewrite -> InteractionId -> Range -> String -> CommandM ()
extlam_dropName :: UnicodeOrAscii -> CaseContext -> String -> String
decorate :: Doc -> String
makeCaseVariant :: CaseContext -> MakeCaseVariant

-- | Sorts interaction points based on their ranges.
sortInteractionPoints :: (MonadInteractionPoints m, MonadError TCErr m, MonadFail m) => [InteractionId] -> m [InteractionId]
instance GHC.Show.Show Agda.Interaction.InteractionTop.GiveRefine
instance GHC.Classes.Eq Agda.Interaction.InteractionTop.GiveRefine

module Agda.Interaction.AgdaTop

-- | <a>repl</a> is a fake ghci interpreter for both the Emacs the JSON
--   frontend
repl :: InteractionOutputCallback -> String -> TCM () -> TCM ()

module Agda.Interaction.EmacsTop

-- | <a>mimicGHCi</a> is a fake ghci interpreter for the Emacs frontend and
--   for interaction tests.
--   
--   <a>mimicGHCi</a> reads the Emacs frontend commands from stdin,
--   interprets them and print the result into stdout.
mimicGHCi :: TCM () -> TCM ()
namedMetaOf :: OutputConstraint Expr a -> a

-- | Print open metas nicely.
showGoals :: Goals -> TCM String

-- | Serializing Info_Error
showInfoError :: Info_Error -> TCM String
explainWhyInScope :: forall m. MonadPretty m => WhyInScopeData -> m Doc

-- | Pretty-prints the context of the given meta-variable.
prettyResponseContext :: InteractionId -> Bool -> [ResponseContextEntry] -> TCM Doc

-- | Pretty-prints the type of the meta-variable.
prettyTypeOfMeta :: Rewrite -> InteractionId -> TCM Doc

module Agda.Interaction.JSONTop

-- | <a>jsonREPL</a> is a interpreter like <a>mimicGHCi</a>, but outputs
--   JSON-encoded strings.
--   
--   <a>jsonREPL</a> reads Haskell values (that starts from <tt>IOTCM</tt>
--   ...) from stdin, interprets them, and outputs JSON-encoded strings.
--   into stdout.
jsonREPL :: TCM () -> TCM ()
instance Agda.Interaction.JSON.EncodeTCM Agda.Syntax.Concrete.Name.NameInScope
instance Data.Aeson.Types.ToJSON.ToJSON Agda.Syntax.Concrete.Name.NameInScope
instance Agda.Interaction.JSON.EncodeTCM Agda.Interaction.Response.Base.Status
instance Data.Aeson.Types.ToJSON.ToJSON Agda.Interaction.Response.Base.Status
instance Agda.Interaction.JSON.EncodeTCM Agda.Interaction.Base.CommandState
instance Data.Aeson.Types.ToJSON.ToJSON Agda.Interaction.Base.CommandState
instance Agda.Interaction.JSON.EncodeTCM Agda.Interaction.Base.CurrentFile
instance Data.Aeson.Types.ToJSON.ToJSON Agda.Interaction.Base.CurrentFile
instance Agda.Interaction.JSON.EncodeTCM Agda.Interaction.Response.Base.ResponseContextEntry
instance Agda.Interaction.JSON.EncodeTCM (Agda.Syntax.Position.Position' ())
instance Data.Aeson.Types.ToJSON.ToJSON (Agda.Syntax.Position.Position' ())
instance Agda.Interaction.JSON.EncodeTCM Agda.Syntax.Position.Range
instance Data.Aeson.Types.ToJSON.ToJSON Agda.Syntax.Position.Range
instance Agda.Interaction.JSON.EncodeTCM Agda.Syntax.Common.ProblemId
instance Agda.Interaction.JSON.EncodeTCM Agda.Syntax.Common.MetaId
instance Data.Aeson.Types.ToJSON.ToJSON Agda.Syntax.Common.ProblemId
instance Data.Aeson.Types.ToJSON.ToJSON Agda.Syntax.TopLevelModuleName.Boot.ModuleNameHash
instance Data.Aeson.Types.ToJSON.ToJSON Agda.Syntax.Common.MetaId
instance Agda.Interaction.JSON.EncodeTCM Agda.Syntax.Common.InteractionId
instance Data.Aeson.Types.ToJSON.ToJSON Agda.Syntax.Common.InteractionId
instance Agda.Interaction.JSON.EncodeTCM Agda.TypeChecking.Monad.Base.NamedMeta
instance Agda.Interaction.JSON.EncodeTCM Agda.Interaction.Response.Base.GiveResult
instance Data.Aeson.Types.ToJSON.ToJSON Agda.Interaction.Response.Base.GiveResult
instance Agda.Interaction.JSON.EncodeTCM Agda.Interaction.Response.Base.MakeCaseVariant
instance Data.Aeson.Types.ToJSON.ToJSON Agda.Interaction.Response.Base.MakeCaseVariant
instance Agda.Interaction.JSON.EncodeTCM Agda.Interaction.Base.Rewrite
instance Data.Aeson.Types.ToJSON.ToJSON Agda.Interaction.Base.Rewrite
instance Agda.Interaction.JSON.EncodeTCM Agda.Utils.Time.CPUTime
instance Data.Aeson.Types.ToJSON.ToJSON Agda.Utils.Time.CPUTime
instance Agda.Interaction.JSON.EncodeTCM Agda.Interaction.Base.ComputeMode
instance Data.Aeson.Types.ToJSON.ToJSON Agda.Interaction.Base.ComputeMode
instance Agda.Interaction.JSON.EncodeTCM (Agda.Interaction.Output.OutputForm Agda.Syntax.Concrete.Expr Agda.Syntax.Concrete.Expr)
instance Agda.Interaction.JSON.EncodeTCM Agda.Syntax.Internal.Blockers.Blocker
instance Agda.Interaction.JSON.EncodeTCM Agda.Interaction.Response.DisplayInfo
instance Agda.Interaction.JSON.EncodeTCM Agda.Interaction.Response.Base.GoalTypeAux
instance Agda.Interaction.JSON.EncodeTCM Agda.Interaction.Response.Info_Error
instance Agda.Interaction.JSON.EncodeTCM Agda.TypeChecking.Monad.Base.TCErr
instance Agda.Interaction.JSON.EncodeTCM Agda.TypeChecking.Monad.Base.TCWarning
instance Agda.Interaction.JSON.EncodeTCM Agda.Interaction.Response.Response

module Agda.Interaction.Highlighting.Dot
dotBackend :: Backend


-- | Generating highlighted and aligned LaTeX from literate Agda source.
module Agda.Interaction.Highlighting.LaTeX
latexBackend :: Backend


-- | Backend for generating highlighted, hyperlinked HTML from Agda
--   sources.
module Agda.Interaction.Highlighting.HTML
htmlBackend :: Backend

module Agda.Compiler.MAlonzo.Compiler
ghcBackend :: Backend

-- | Option strings to activate the GHC backend.
ghcInvocationStrings :: [String]
instance GHC.Generics.Generic Agda.Compiler.MAlonzo.Compiler.GHCFlags
instance GHC.Show.Show Agda.Compiler.MAlonzo.Compiler.UsesFloat
instance GHC.Classes.Eq Agda.Compiler.MAlonzo.Compiler.UsesFloat
instance GHC.Base.Semigroup Agda.Compiler.MAlonzo.Compiler.UsesFloat
instance GHC.Base.Monoid Agda.Compiler.MAlonzo.Compiler.UsesFloat
instance GHC.Base.Monad m => Agda.Compiler.MAlonzo.Compiler.ReadGHCOpts (Control.Monad.Trans.Reader.ReaderT Agda.Compiler.MAlonzo.Compiler.GHCModule m)
instance GHC.Base.Monad m => Agda.Compiler.MAlonzo.Misc.ReadGHCModuleEnv (Control.Monad.Trans.Reader.ReaderT Agda.Compiler.MAlonzo.Compiler.GHCModule m)
instance GHC.Base.Monad m => Agda.Compiler.MAlonzo.Compiler.ReadGHCOpts (Control.Monad.Trans.Reader.ReaderT Agda.Compiler.MAlonzo.Misc.GHCOptions m)
instance GHC.Base.Monad m => Agda.Compiler.MAlonzo.Compiler.ReadGHCOpts (Control.Monad.Trans.Reader.ReaderT Agda.Compiler.MAlonzo.Misc.GHCEnv m)
instance GHC.Base.Monad m => Agda.Compiler.MAlonzo.Compiler.ReadGHCOpts (Control.Monad.Trans.Reader.ReaderT Agda.Compiler.MAlonzo.Misc.GHCModuleEnv m)
instance Control.DeepSeq.NFData Agda.Compiler.MAlonzo.Compiler.GHCFlags


-- | Main module for JS backend.
module Agda.Compiler.JS.Compiler
jsBackend :: Backend
jsBackend' :: Backend' JSOptions JSOptions JSModuleEnv Module (Maybe Export)
data JSOptions
JSOptions :: Bool -> Bool -> Bool -> Bool -> JSModuleStyle -> JSOptions
[optJSCompile] :: JSOptions -> Bool
[optJSOptimize] :: JSOptions -> Bool

-- | Remove spaces etc. See
--   <a>https://en.wikipedia.org/wiki/Minification_(programming)</a>.
[optJSMinify] :: JSOptions -> Bool

-- | Run generated code through interpreter.
[optJSVerify] :: JSOptions -> Bool
[optJSModuleStyle] :: JSOptions -> JSModuleStyle
defaultJSOptions :: JSOptions
jsCommandLineFlags :: [OptDescr (Flag JSOptions)]
jsPreCompile :: JSOptions -> TCM JSOptions

-- | After all modules have been compiled, copy RTE modules and verify
--   compiled modules.
jsPostCompile :: JSOptions -> IsMain -> Map TopLevelModuleName Module -> TCM ()
data JSModuleEnv
JSModuleEnv :: Maybe CoinductionKit -> Bool -> JSModuleEnv
[jsCoinductionKit] :: JSModuleEnv -> Maybe CoinductionKit

-- | Should this module be compiled?
[jsCompile] :: JSModuleEnv -> Bool
jsPreModule :: JSOptions -> IsMain -> TopLevelModuleName -> Maybe FilePath -> TCM (Recompile JSModuleEnv Module)
jsPostModule :: JSOptions -> JSModuleEnv -> IsMain -> TopLevelModuleName -> [Maybe Export] -> TCM Module
jsCompileDef :: JSOptions -> JSModuleEnv -> IsMain -> Definition -> TCM (Maybe Export)
prefix :: [Char]
jsMod :: TopLevelModuleName -> GlobalId
jsFileName :: GlobalId -> String
jsMember :: Name -> MemberId
global' :: QName -> TCM (Exp, JSQName)
global :: QName -> TCM (Exp, JSQName)
reorder :: [Export] -> [Export]
reorder' :: Set JSQName -> [Export] -> [Export]
isTopLevelValue :: Export -> Bool
isEmptyObject :: Export -> Bool
insertAfter :: Set JSQName -> Export -> [Export] -> [Export]
type EnvWithOpts = (JSOptions, JSModuleEnv)
definition :: EnvWithOpts -> (QName, Definition) -> TCM (Maybe Export)

-- | Ensure that there is at most one pragma for a name.
checkCompilerPragmas :: QName -> TCM ()
defJSDef :: Definition -> Maybe String
definition' :: EnvWithOpts -> QName -> Definition -> Type -> JSQName -> TCM (Maybe Export)
compileTerm :: EnvWithOpts -> TTerm -> TCM Exp
compilePrim :: TPrim -> Exp
compileAlt :: EnvWithOpts -> TAlt -> TCM ((QName, MemberId), Exp)
eraseLocalVars :: [Bool] -> TTerm -> TTerm
visitorName :: QName -> TCM MemberId
flatName :: MemberId
local :: Nat -> Exp
qname :: QName -> TCM Exp
literal :: Literal -> Exp
litqname :: QName -> Exp
litmeta :: MetaId -> Exp
writeModule :: Bool -> JSModuleStyle -> Module -> TCM ()
outFile :: GlobalId -> TCM FilePath
outFile_ :: TCM FilePath

-- | Primitives implemented in the JS Agda RTS.
--   
--   TODO: Primitives that are not part of this set, and for which
--   <a>defJSDef</a> does not return anything, are silently compiled to
--   <a>Undefined</a>. A better approach might be to list exactly those
--   primitives which should be compiled to <a>Undefined</a>.
primitives :: Set PrimitiveId
instance GHC.Generics.Generic Agda.Compiler.JS.Compiler.JSOptions
instance Control.DeepSeq.NFData Agda.Compiler.JS.Compiler.JSOptions
instance Control.DeepSeq.NFData Agda.Compiler.JS.Pretty.JSModuleStyle


-- | Built-in backends.
module Agda.Compiler.Builtin
builtinBackends :: [Backend]


-- | Agda main module.
module Agda.Main

-- | The main function
runAgda :: [Backend] -> IO ()

-- | The main function without importing built-in backends
runAgda' :: [Backend] -> IO ()

-- | Main execution mode
data MainMode
MainModeRun :: Interactor () -> MainMode
MainModePrintHelp :: Help -> MainMode
MainModePrintVersion :: PrintAgdaVersion -> MainMode
MainModePrintAgdaDataDir :: MainMode
MainModePrintAgdaAppDir :: MainMode

-- | Determine the main execution mode to run, based on the configured
--   backends and command line options. | This is pure.
getMainMode :: MonadError String m => [Backend] -> Maybe AbsolutePath -> CommandLineOptions -> m MainMode
type Interactor a = TCM () -> (AbsolutePath -> TCM CheckResult) -> TCM a
data FrontendType
FrontEndEmacs :: FrontendType
FrontEndJson :: FrontendType
FrontEndRepl :: FrontendType
emacsModeInteractor :: Interactor ()
jsonModeInteractor :: Interactor ()
replInteractor :: Maybe AbsolutePath -> Interactor ()
defaultInteractor :: AbsolutePath -> Interactor ()
getInteractor :: MonadError String m => [Backend] -> Maybe AbsolutePath -> CommandLineOptions -> m (Maybe (Interactor ()))

-- | Run Agda with parsed command line options
runAgdaWithOptions :: Interactor a -> String -> CommandLineOptions -> TCM a

-- | Print usage information.
printUsage :: [Backend] -> Help -> IO ()
backendUsage :: Backend -> String

-- | Print version information.
printVersion :: [Backend] -> PrintAgdaVersion -> IO ()
printAgdaDataDir :: IO ()
printAgdaAppDir :: IO ()

-- | What to do for bad options.
optionError :: String -> IO ()

-- | Run a TCM action in IO; catch and pretty print errors.
runTCMPrettyErrors :: TCM () -> IO ()

-- | If the error is an IO error, and the error message suggests that the
--   problem is related to locales or code pages, print out some extra
--   information.
helpForLocaleError :: TCErr -> IO ()