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:
Edwin Brady 2019-05-04 23:32:41 +01:00
parent 257d381524
commit 78fbfc84a8
3 changed files with 85 additions and 10 deletions

View File

@ -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) pure (MkArgInfo idx argRig (appInf Nothing p) arg argTy :: rest, restTy)
mkArgs fc rigc env ty = pure ([], ty) 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) 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)) = 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} -> searchIfHole : {auto c : Ref Ctxt Defs} ->
{auto u : Ref UST UState} -> {auto u : Ref UST UState} ->
@ -146,19 +152,74 @@ searchLocal : {auto c : Ref Ctxt Defs} ->
(target : NF vars) -> Core (NF vars) (target : NF vars) -> Core (NF vars)
searchLocal fc rigc defaults depth def top env locs [] target searchLocal fc rigc defaults depth def top env locs [] target
= throw (CantSolveGoal fc env top) = 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 = 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 -- TODO: Can only use the local if it's not an unsolved hole
ures <- unify InTerm fc env target appTy ures <- unify InTerm fc env target appTy
let [] = constraints ures let [] = constraints ures
| _ => throw (CantSolveGoal fc env top) | _ => throw (CantSolveGoal fc env top)
candidate <- closureApply fc c args candidate <- closureApply fc env (f prf) args
logTermNF 10 "Candidate " env candidate logTermNF 10 "Candidate " env candidate
traverse (searchIfHole fc defaults depth def top env locs) args traverse (searchIfHole fc defaults depth def top env locs) args
defs <- get Ctxt defs <- get Ctxt
nf defs env candidate) nf defs env candidate
(searchLocal fc rigc defaults depth def top env locs rest target)
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} -> searchName : {auto c : Ref Ctxt Defs} ->
{auto u : Ref UST UState} -> {auto u : Ref UST UState} ->

View File

@ -793,6 +793,17 @@ addData vis (MkData (MkCon dfc tyn arity tycon) datacons)
(idx, gam') <- addCtxt n condef gam (idx, gam') <- addCtxt n condef gam
addDataConstructors (tag + 1) cs 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 -- 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, -- i.e. if it doesn't have an explicit namespace already, add it,
-- otherwise leave it alone -- otherwise leave it alone
@ -937,7 +948,7 @@ checkUnambig fc n
= do defs <- get Ctxt = do defs <- get Ctxt
case !(lookupDefName n (gamma defs)) of case !(lookupDefName n (gamma defs)) of
[] => throw (UndefinedName fc n) [] => throw (UndefinedName fc n)
[(fulln, _)] => pure fulln [(fulln, i, _)] => pure (Resolved i)
ns => throw (AmbiguousName fc (map fst ns)) ns => throw (AmbiguousName fc (map fst ns))
export export

View File

@ -24,7 +24,10 @@ processDecl env (IData fc vis ddef)
processDecl env (IDef fc fname def) processDecl env (IDef fc fname def)
= processDef env fc fname def = processDef env fc fname def
processDecl env (INamespace fc ns decls) processDecl env (INamespace fc ns decls)
= ?processNamespace = do oldns <- getNS
extendNS (reverse ns)
traverse (processDecl env) decls
setNS oldns
processDecl {c} env (IPragma act) processDecl {c} env (IPragma act)
= act c env = act c env
processDecl env (ILog n) processDecl env (ILog n)