mirror of
https://github.com/edwinb/Idris2-boot.git
synced 2025-01-04 19:05:25 +03:00
searchLocal looks inside pairs
We'll need this for interface resolution - build up applications of fst and snd as we go deeper. This also adds options for controlling names of pairs, proofs, primitives, etc.
This commit is contained in:
parent
257d381524
commit
78fbfc84a8
@ -57,11 +57,17 @@ mkArgs fc rigc env (NBind nfc x (Pi c p ty) sc)
|
||||
pure (MkArgInfo idx argRig (appInf Nothing p) arg argTy :: rest, restTy)
|
||||
mkArgs fc rigc env ty = pure ([], ty)
|
||||
|
||||
closureApply : FC -> Closure vars -> List (ArgInfo vars) ->
|
||||
closureApply : {auto c : Ref Ctxt Defs} ->
|
||||
FC -> Env Term vars -> Closure vars -> List (ArgInfo vars) ->
|
||||
Core (Term vars)
|
||||
closureApply fc (MkClosure _ [] _ tm) args
|
||||
closureApply fc env (MkClosure _ [] _ tm) args
|
||||
= pure (applyInfo fc tm (map (\i => (appInf i, metaApp i)) args))
|
||||
closureApply _ _ _ = throw (InternalError "Wrong argument form in AutoSearch")
|
||||
closureApply fc env (MkNFClosure nf) args
|
||||
= do defs <- get Ctxt
|
||||
empty <- clearDefs defs
|
||||
tm <- quote empty env nf
|
||||
pure (applyInfo fc tm (map (\i => (appInf i, metaApp i)) args))
|
||||
closureApply _ _ _ _ = throw (InternalError "Wrong argument form in AutoSearch")
|
||||
|
||||
searchIfHole : {auto c : Ref Ctxt Defs} ->
|
||||
{auto u : Ref UST UState} ->
|
||||
@ -146,19 +152,74 @@ searchLocal : {auto c : Ref Ctxt Defs} ->
|
||||
(target : NF vars) -> Core (NF vars)
|
||||
searchLocal fc rigc defaults depth def top env locs [] target
|
||||
= throw (CantSolveGoal fc env top)
|
||||
searchLocal fc rigc defaults depth def top env locs ((ty, c) :: rest) target
|
||||
searchLocal {vars} fc rigc defaults depth def top env locs ((ty, c) :: rest) target
|
||||
= tryUnify
|
||||
(do (args, appTy) <- mkArgs fc rigc env ty
|
||||
(do defs <- get Ctxt
|
||||
findPos defs c id ty target)
|
||||
|
||||
-- do (args, appTy) <- mkArgs fc rigc env ty
|
||||
-- -- TODO: Can only use the local if it's not an unsolved hole
|
||||
-- ures <- unify InTerm fc env target appTy
|
||||
-- let [] = constraints ures
|
||||
-- | _ => throw (CantSolveGoal fc env top)
|
||||
-- candidate <- closureApply fc c args
|
||||
-- logTermNF 10 "Candidate " env candidate
|
||||
-- traverse (searchIfHole fc defaults depth def top env locs) args
|
||||
-- defs <- get Ctxt
|
||||
-- nf defs env candidate)
|
||||
(searchLocal fc rigc defaults depth def top env locs rest target)
|
||||
where
|
||||
findDirect : Defs -> Closure vars ->
|
||||
(Closure vars -> Closure vars) ->
|
||||
NF vars -> -- local's type
|
||||
(target : NF vars) ->
|
||||
Core (NF vars)
|
||||
findDirect defs prf f ty target
|
||||
= do (args, appTy) <- mkArgs fc rigc env ty
|
||||
-- TODO: Can only use the local if it's not an unsolved hole
|
||||
ures <- unify InTerm fc env target appTy
|
||||
let [] = constraints ures
|
||||
| _ => throw (CantSolveGoal fc env top)
|
||||
candidate <- closureApply fc c args
|
||||
candidate <- closureApply fc env (f prf) args
|
||||
logTermNF 10 "Candidate " env candidate
|
||||
traverse (searchIfHole fc defaults depth def top env locs) args
|
||||
defs <- get Ctxt
|
||||
nf defs env candidate)
|
||||
(searchLocal fc rigc defaults depth def top env locs rest target)
|
||||
nf defs env candidate
|
||||
|
||||
findPos : Defs -> Closure vars ->
|
||||
(Closure vars -> Closure vars) ->
|
||||
NF vars -> -- local's type
|
||||
(target : NF vars) ->
|
||||
Core (NF vars)
|
||||
findPos defs prf f ty@(NTCon pfc pn _ _ [(xp, xty), (yp, yty)]) target
|
||||
= tryUnify (findDirect defs prf f ty target)
|
||||
(do log 0 (show (pn, isPairType pn defs, fstName defs))
|
||||
fname <- maybe (throw (CantSolveGoal fc env top))
|
||||
pure
|
||||
(fstName defs)
|
||||
sname <- maybe (throw (CantSolveGoal fc env top))
|
||||
pure
|
||||
(sndName defs)
|
||||
if isPairType pn defs
|
||||
then tryUnify
|
||||
(do xtynf <- evalClosure defs xty
|
||||
logNF 0 "Trying fst" env xtynf
|
||||
findPos defs prf
|
||||
(\arg => MkNFClosure $ NApp fc (NRef Func fname)
|
||||
[(xp, xty),
|
||||
(yp, yty),
|
||||
(explApp Nothing, f arg)])
|
||||
xtynf target)
|
||||
(do ytynf <- evalClosure defs yty
|
||||
findPos defs prf
|
||||
(\arg => MkNFClosure $ NApp fc (NRef Func sname)
|
||||
[(xp, xty),
|
||||
(yp, yty),
|
||||
(explApp Nothing, f arg)])
|
||||
ytynf target)
|
||||
else throw (CantSolveGoal fc env top))
|
||||
findPos defs prf f ty target
|
||||
= findDirect defs prf f ty target
|
||||
|
||||
searchName : {auto c : Ref Ctxt Defs} ->
|
||||
{auto u : Ref UST UState} ->
|
||||
|
@ -793,6 +793,17 @@ addData vis (MkData (MkCon dfc tyn arity tycon) datacons)
|
||||
(idx, gam') <- addCtxt n condef gam
|
||||
addDataConstructors (tag + 1) cs gam'
|
||||
|
||||
-- Add a new nested namespace to the current namespace for new definitions
|
||||
-- e.g. extendNS ["Data"] when namespace is "Prelude.List" leads to
|
||||
-- current namespace of "Prelude.List.Data"
|
||||
-- Inner namespaces go first, for ease of name lookup
|
||||
export
|
||||
extendNS : {auto c : Ref Ctxt Defs} ->
|
||||
List String -> Core ()
|
||||
extendNS ns
|
||||
= do defs <- get Ctxt
|
||||
put Ctxt (record { currentNS $= ((reverse ns) ++) } defs)
|
||||
|
||||
-- Get the name as it would be defined in the current namespace
|
||||
-- i.e. if it doesn't have an explicit namespace already, add it,
|
||||
-- otherwise leave it alone
|
||||
@ -937,7 +948,7 @@ checkUnambig fc n
|
||||
= do defs <- get Ctxt
|
||||
case !(lookupDefName n (gamma defs)) of
|
||||
[] => throw (UndefinedName fc n)
|
||||
[(fulln, _)] => pure fulln
|
||||
[(fulln, i, _)] => pure (Resolved i)
|
||||
ns => throw (AmbiguousName fc (map fst ns))
|
||||
|
||||
export
|
||||
|
@ -24,7 +24,10 @@ processDecl env (IData fc vis ddef)
|
||||
processDecl env (IDef fc fname def)
|
||||
= processDef env fc fname def
|
||||
processDecl env (INamespace fc ns decls)
|
||||
= ?processNamespace
|
||||
= do oldns <- getNS
|
||||
extendNS (reverse ns)
|
||||
traverse (processDecl env) decls
|
||||
setNS oldns
|
||||
processDecl {c} env (IPragma act)
|
||||
= act c env
|
||||
processDecl env (ILog n)
|
||||
|
Loading…
Reference in New Issue
Block a user