mirror of
https://github.com/idris-lang/Idris2.git
synced 2025-01-07 08:18:12 +03:00
[cleanup] Remove Libraries.Data.Bool.Extra
This commit is contained in:
parent
2061982699
commit
0df331690a
@ -115,7 +115,6 @@ modules =
|
|||||||
Libraries.Control.Delayed,
|
Libraries.Control.Delayed,
|
||||||
|
|
||||||
Libraries.Data.ANameMap,
|
Libraries.Data.ANameMap,
|
||||||
Libraries.Data.Bool.Extra,
|
|
||||||
Libraries.Data.DList,
|
Libraries.Data.DList,
|
||||||
Libraries.Data.IMaybe,
|
Libraries.Data.IMaybe,
|
||||||
Libraries.Data.IntMap,
|
Libraries.Data.IntMap,
|
||||||
|
@ -8,7 +8,6 @@ import Core.Context
|
|||||||
import Core.Name
|
import Core.Name
|
||||||
import Core.TT
|
import Core.TT
|
||||||
|
|
||||||
import Libraries.Data.Bool.Extra
|
|
||||||
import Data.List
|
import Data.List
|
||||||
import Data.Vect
|
import Data.Vect
|
||||||
|
|
||||||
@ -294,17 +293,17 @@ mutual
|
|||||||
used n (NmRef _ _) = False
|
used n (NmRef _ _) = False
|
||||||
used n (NmLam _ _ sc) = used n sc
|
used n (NmLam _ _ sc) = used n sc
|
||||||
used n (NmLet _ _ v sc) = used n v || used n sc
|
used n (NmLet _ _ v sc) = used n v || used n sc
|
||||||
used n (NmApp _ f args) = used n f || anyTrue (map (used n) args)
|
used n (NmApp _ f args) = used n f || any (used n) args
|
||||||
used n (NmCon _ _ _ _ args) = anyTrue (map (used n) args)
|
used n (NmCon _ _ _ _ args) = any (used n) args
|
||||||
used n (NmOp _ _ args) = anyTrue (toList (map (used n) args))
|
used n (NmOp _ _ args) = any (used n) (toList args)
|
||||||
used n (NmExtPrim _ _ args) = anyTrue (map (used n) args)
|
used n (NmExtPrim _ _ args) = any (used n) args
|
||||||
used n (NmForce _ _ t) = used n t
|
used n (NmForce _ _ t) = used n t
|
||||||
used n (NmDelay _ _ t) = used n t
|
used n (NmDelay _ _ t) = used n t
|
||||||
used n (NmConCase _ sc alts def)
|
used n (NmConCase _ sc alts def)
|
||||||
= used n sc || anyTrue (map (usedCon n) alts)
|
= used n sc || any (usedCon n) alts
|
||||||
|| maybe False (used n) def
|
|| maybe False (used n) def
|
||||||
used n (NmConstCase _ sc alts def)
|
used n (NmConstCase _ sc alts def)
|
||||||
= used n sc || anyTrue (map (usedConst n) alts)
|
= used n sc || any (usedConst n) alts
|
||||||
|| maybe False (used n) def
|
|| maybe False (used n) def
|
||||||
used n _ = False
|
used n _ = False
|
||||||
|
|
||||||
|
@ -9,7 +9,6 @@ import Core.TT
|
|||||||
import Core.Unify
|
import Core.Unify
|
||||||
import Core.Value
|
import Core.Value
|
||||||
|
|
||||||
import Libraries.Data.Bool.Extra
|
|
||||||
import Data.Either
|
import Data.Either
|
||||||
import Data.List
|
import Data.List
|
||||||
import Data.Maybe
|
import Data.Maybe
|
||||||
@ -222,12 +221,12 @@ usableLocal loc defaults env (NDCon _ n _ _ args)
|
|||||||
= do defs <- get Ctxt
|
= do defs <- get Ctxt
|
||||||
us <- traverse (usableLocal loc defaults env)
|
us <- traverse (usableLocal loc defaults env)
|
||||||
!(traverse (evalClosure defs) $ map snd args)
|
!(traverse (evalClosure defs) $ map snd args)
|
||||||
pure (allTrue us)
|
pure (all id us)
|
||||||
usableLocal loc defaults env (NApp _ (NLocal _ _ _) args)
|
usableLocal loc defaults env (NApp _ (NLocal _ _ _) args)
|
||||||
= do defs <- get Ctxt
|
= do defs <- get Ctxt
|
||||||
us <- traverse (usableLocal loc defaults env)
|
us <- traverse (usableLocal loc defaults env)
|
||||||
!(traverse (evalClosure defs) $ map snd args)
|
!(traverse (evalClosure defs) $ map snd args)
|
||||||
pure (allTrue us)
|
pure (all id us)
|
||||||
usableLocal loc defaults env (NBind fc x (Pi _ _ _ _) sc)
|
usableLocal loc defaults env (NBind fc x (Pi _ _ _ _) sc)
|
||||||
= do defs <- get Ctxt
|
= do defs <- get Ctxt
|
||||||
usableLocal loc defaults env
|
usableLocal loc defaults env
|
||||||
|
@ -2,10 +2,10 @@ module Core.CaseTree
|
|||||||
|
|
||||||
import Core.TT
|
import Core.TT
|
||||||
|
|
||||||
import Libraries.Data.Bool.Extra
|
import Data.Bool
|
||||||
import Data.List
|
import Data.List
|
||||||
import Libraries.Data.NameMap
|
|
||||||
|
|
||||||
|
import Libraries.Data.NameMap
|
||||||
import Libraries.Text.PrettyPrint.Prettyprinter
|
import Libraries.Text.PrettyPrint.Prettyprinter
|
||||||
|
|
||||||
%default covering
|
%default covering
|
||||||
@ -159,7 +159,7 @@ mutual
|
|||||||
eqTree (Case i _ _ alts) (Case i' _ _ alts')
|
eqTree (Case i _ _ alts) (Case i' _ _ alts')
|
||||||
= i == i'
|
= i == i'
|
||||||
&& length alts == length alts'
|
&& length alts == length alts'
|
||||||
&& allTrue (zipWith eqAlt alts alts')
|
&& all (uncurry eqAlt) (zip alts alts')
|
||||||
eqTree (STerm _ t) (STerm _ t') = eqTerm t t'
|
eqTree (STerm _ t) (STerm _ t') = eqTerm t t'
|
||||||
eqTree (Unmatched _) (Unmatched _) = True
|
eqTree (Unmatched _) (Unmatched _) = True
|
||||||
eqTree Impossible Impossible = True
|
eqTree Impossible Impossible = True
|
||||||
|
@ -8,10 +8,10 @@ import Core.Normalise
|
|||||||
import Core.TT
|
import Core.TT
|
||||||
import Core.Value
|
import Core.Value
|
||||||
|
|
||||||
import Libraries.Data.Bool.Extra
|
|
||||||
import Data.List
|
import Data.List
|
||||||
import Data.Maybe
|
import Data.Maybe
|
||||||
import Data.Strings
|
import Data.Strings
|
||||||
|
|
||||||
import Libraries.Data.NameMap
|
import Libraries.Data.NameMap
|
||||||
import Libraries.Text.PrettyPrint.Prettyprinter
|
import Libraries.Text.PrettyPrint.Prettyprinter
|
||||||
import Libraries.Data.String.Extra
|
import Libraries.Data.String.Extra
|
||||||
@ -48,7 +48,7 @@ conflictMatch ((x, tm) :: ms) = conflictArgs x tm ms || conflictMatch ms
|
|||||||
findN i tm
|
findN i tm
|
||||||
= let (Ref _ (DataCon _ _) _, args) = getFnArgs tm
|
= let (Ref _ (DataCon _ _) _, args) = getFnArgs tm
|
||||||
| _ => False in
|
| _ => False in
|
||||||
anyTrue (map (findN i) args)
|
any (findN i) args
|
||||||
|
|
||||||
-- Assuming in normal form. Look for: mismatched constructors, or
|
-- Assuming in normal form. Look for: mismatched constructors, or
|
||||||
-- a name appearing strong rigid in the other term
|
-- a name appearing strong rigid in the other term
|
||||||
@ -56,15 +56,15 @@ conflictMatch ((x, tm) :: ms) = conflictArgs x tm ms || conflictMatch ms
|
|||||||
conflictTm (Local _ _ i _) tm
|
conflictTm (Local _ _ i _) tm
|
||||||
= let (Ref _ (DataCon _ _) _, args) = getFnArgs tm
|
= let (Ref _ (DataCon _ _) _, args) = getFnArgs tm
|
||||||
| _ => False in
|
| _ => False in
|
||||||
anyTrue (map (findN i) args)
|
any (findN i) args
|
||||||
conflictTm tm (Local _ _ i _)
|
conflictTm tm (Local _ _ i _)
|
||||||
= let (Ref _ (DataCon _ _) _, args) = getFnArgs tm
|
= let (Ref _ (DataCon _ _) _, args) = getFnArgs tm
|
||||||
| _ => False in
|
| _ => False in
|
||||||
anyTrue (map (findN i) args)
|
any (findN i) args
|
||||||
conflictTm tm tm'
|
conflictTm tm tm'
|
||||||
= let (f, args) = getFnArgs tm
|
= let (f, args) = getFnArgs tm
|
||||||
(f', args') = getFnArgs tm' in
|
(f', args') = getFnArgs tm' in
|
||||||
clash f f' || anyTrue (zipWith conflictTm args args')
|
clash f f' || any (uncurry conflictTm) (zip args args')
|
||||||
|
|
||||||
conflictArgs : Name -> Term vars -> List (Name, Term vars) -> Bool
|
conflictArgs : Name -> Term vars -> List (Name, Term vars) -> Bool
|
||||||
conflictArgs n tm [] = False
|
conflictArgs n tm [] = False
|
||||||
|
@ -11,7 +11,6 @@ import Core.UnifyState
|
|||||||
import Core.Value
|
import Core.Value
|
||||||
import Core.TT
|
import Core.TT
|
||||||
|
|
||||||
import Libraries.Data.Bool.Extra
|
|
||||||
import Data.List
|
import Data.List
|
||||||
|
|
||||||
%default covering
|
%default covering
|
||||||
@ -108,7 +107,7 @@ mutual
|
|||||||
let vars = mapMaybe (findLocal (getArgs lhs)) argpos
|
let vars = mapMaybe (findLocal (getArgs lhs)) argpos
|
||||||
hs <- traverse (\vsel => updateHoleUsage useInHole vsel [] rhs)
|
hs <- traverse (\vsel => updateHoleUsage useInHole vsel [] rhs)
|
||||||
vars
|
vars
|
||||||
pure (anyTrue hs)
|
pure (any id hs)
|
||||||
where
|
where
|
||||||
findArg : Nat -> List (Term vars) -> List Nat
|
findArg : Nat -> List (Term vars) -> List Nat
|
||||||
findArg i [] = []
|
findArg i [] = []
|
||||||
|
@ -3,12 +3,12 @@ module Core.TT
|
|||||||
import public Core.FC
|
import public Core.FC
|
||||||
import public Core.Name
|
import public Core.Name
|
||||||
|
|
||||||
import Libraries.Data.Bool.Extra
|
|
||||||
import Data.List
|
import Data.List
|
||||||
import Data.Nat
|
import Data.Nat
|
||||||
import Libraries.Data.NameMap
|
|
||||||
import Data.Vect
|
import Data.Vect
|
||||||
import Decidable.Equality
|
import Decidable.Equality
|
||||||
|
|
||||||
|
import Libraries.Data.NameMap
|
||||||
import Libraries.Text.PrettyPrint.Prettyprinter
|
import Libraries.Text.PrettyPrint.Prettyprinter
|
||||||
import Libraries.Text.PrettyPrint.Prettyprinter.Util
|
import Libraries.Text.PrettyPrint.Prettyprinter.Util
|
||||||
|
|
||||||
@ -873,7 +873,7 @@ eqTerm : Term vs -> Term vs' -> Bool
|
|||||||
eqTerm (Local _ _ idx _) (Local _ _ idx' _) = idx == idx'
|
eqTerm (Local _ _ idx _) (Local _ _ idx' _) = idx == idx'
|
||||||
eqTerm (Ref _ _ n) (Ref _ _ n') = n == n'
|
eqTerm (Ref _ _ n) (Ref _ _ n') = n == n'
|
||||||
eqTerm (Meta _ _ i args) (Meta _ _ i' args')
|
eqTerm (Meta _ _ i args) (Meta _ _ i' args')
|
||||||
= assert_total (i == i' && allTrue (zipWith eqTerm args args'))
|
= assert_total (i == i' && all (uncurry eqTerm) (zip args args'))
|
||||||
eqTerm (Bind _ _ b sc) (Bind _ _ b' sc')
|
eqTerm (Bind _ _ b sc) (Bind _ _ b' sc')
|
||||||
= assert_total (eqBinderBy eqTerm b b') && eqTerm sc sc'
|
= assert_total (eqBinderBy eqTerm b b') && eqTerm sc sc'
|
||||||
eqTerm (App _ f a) (App _ f' a') = eqTerm f f' && eqTerm a a'
|
eqTerm (App _ f a) (App _ f' a') = eqTerm f f' && eqTerm a a'
|
||||||
|
@ -12,10 +12,10 @@ import Core.TT
|
|||||||
import public Core.UnifyState
|
import public Core.UnifyState
|
||||||
import Core.Value
|
import Core.Value
|
||||||
|
|
||||||
import Libraries.Data.Bool.Extra
|
|
||||||
import Libraries.Data.IntMap
|
|
||||||
import Data.List
|
import Data.List
|
||||||
import Data.List.Views
|
import Data.List.Views
|
||||||
|
|
||||||
|
import Libraries.Data.IntMap
|
||||||
import Libraries.Data.NameMap
|
import Libraries.Data.NameMap
|
||||||
|
|
||||||
%default covering
|
%default covering
|
||||||
@ -1500,7 +1500,7 @@ solveConstraints : {auto c : Ref Ctxt Defs} ->
|
|||||||
solveConstraints umode smode
|
solveConstraints umode smode
|
||||||
= do ust <- get UST
|
= do ust <- get UST
|
||||||
progress <- traverse (retryGuess umode smode) (toList (guesses ust))
|
progress <- traverse (retryGuess umode smode) (toList (guesses ust))
|
||||||
when (anyTrue progress) $
|
when (any id progress) $
|
||||||
solveConstraints umode Normal
|
solveConstraints umode Normal
|
||||||
|
|
||||||
export
|
export
|
||||||
@ -1511,7 +1511,7 @@ solveConstraintsAfter start umode smode
|
|||||||
= do ust <- get UST
|
= do ust <- get UST
|
||||||
progress <- traverse (retryGuess umode smode)
|
progress <- traverse (retryGuess umode smode)
|
||||||
(filter afterStart (toList (guesses ust)))
|
(filter afterStart (toList (guesses ust)))
|
||||||
when (anyTrue progress) $
|
when (any id progress) $
|
||||||
solveConstraintsAfter start umode Normal
|
solveConstraintsAfter start umode Normal
|
||||||
where
|
where
|
||||||
afterStart : (Int, a) -> Bool
|
afterStart : (Int, a) -> Bool
|
||||||
|
@ -1,48 +0,0 @@
|
|||||||
module Libraries.Data.Bool.Extra
|
|
||||||
|
|
||||||
%default total
|
|
||||||
|
|
||||||
public export
|
|
||||||
andSameNeutral : (x : Bool) -> x && x = x
|
|
||||||
andSameNeutral False = Refl
|
|
||||||
andSameNeutral True = Refl
|
|
||||||
|
|
||||||
public export
|
|
||||||
andFalseFalse : (x : Bool) -> x && False = False
|
|
||||||
andFalseFalse False = Refl
|
|
||||||
andFalseFalse True = Refl
|
|
||||||
|
|
||||||
public export
|
|
||||||
andTrueNeutral : (x : Bool) -> x && True = x
|
|
||||||
andTrueNeutral False = Refl
|
|
||||||
andTrueNeutral True = Refl
|
|
||||||
|
|
||||||
public export
|
|
||||||
orSameNeutral : (x : Bool) -> x || x = x
|
|
||||||
orSameNeutral False = Refl
|
|
||||||
orSameNeutral True = Refl
|
|
||||||
|
|
||||||
public export
|
|
||||||
orFalseNeutral : (x : Bool) -> x || False = x
|
|
||||||
orFalseNeutral False = Refl
|
|
||||||
orFalseNeutral True = Refl
|
|
||||||
|
|
||||||
public export
|
|
||||||
orTrueTrue : (x : Bool) -> x || True = True
|
|
||||||
orTrueTrue False = Refl
|
|
||||||
orTrueTrue True = Refl
|
|
||||||
|
|
||||||
public export
|
|
||||||
orSameAndRightNeutral : (x, right : Bool) -> x || (x && right) = x
|
|
||||||
orSameAndRightNeutral False _ = Refl
|
|
||||||
orSameAndRightNeutral True _ = Refl
|
|
||||||
|
|
||||||
export
|
|
||||||
anyTrue : List Bool -> Bool
|
|
||||||
anyTrue [] = False
|
|
||||||
anyTrue (x :: xs) = x || anyTrue xs
|
|
||||||
|
|
||||||
export
|
|
||||||
allTrue : List Bool -> Bool
|
|
||||||
allTrue [] = True
|
|
||||||
allTrue (x :: xs) = x && allTrue xs
|
|
@ -1,6 +1,6 @@
|
|||||||
module Libraries.Text.Lexer
|
module Libraries.Text.Lexer
|
||||||
|
|
||||||
import Libraries.Data.Bool.Extra
|
import Data.Bool
|
||||||
import Data.List
|
import Data.List
|
||||||
import Data.Nat
|
import Data.Nat
|
||||||
|
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
module Libraries.Text.Lexer.Core
|
module Libraries.Text.Lexer.Core
|
||||||
|
|
||||||
import public Libraries.Control.Delayed
|
|
||||||
import Libraries.Data.Bool.Extra
|
|
||||||
import Data.List
|
import Data.List
|
||||||
import Data.Maybe
|
import Data.Maybe
|
||||||
import Data.Nat
|
import Data.Nat
|
||||||
import Data.Strings
|
import Data.Strings
|
||||||
|
|
||||||
|
import public Libraries.Control.Delayed
|
||||||
import public Libraries.Text.Bounded
|
import public Libraries.Text.Bounded
|
||||||
|
|
||||||
%default total
|
%default total
|
||||||
|
@ -1,17 +1,18 @@
|
|||||||
module Libraries.Text.Lexer.Tokenizer
|
module Libraries.Text.Lexer.Tokenizer
|
||||||
|
|
||||||
import public Libraries.Control.Delayed
|
import Data.List
|
||||||
import public Libraries.Text.Bounded
|
import Data.Either
|
||||||
import Libraries.Data.Bool.Extra
|
import Data.Nat
|
||||||
|
import Data.Strings
|
||||||
|
|
||||||
import Libraries.Data.String.Extra
|
import Libraries.Data.String.Extra
|
||||||
import Libraries.Text.Lexer.Core
|
import Libraries.Text.Lexer.Core
|
||||||
import Libraries.Text.Lexer
|
import Libraries.Text.Lexer
|
||||||
import Libraries.Text.PrettyPrint.Prettyprinter
|
import Libraries.Text.PrettyPrint.Prettyprinter
|
||||||
import Libraries.Text.PrettyPrint.Prettyprinter.Util
|
import Libraries.Text.PrettyPrint.Prettyprinter.Util
|
||||||
import Data.List
|
|
||||||
import Data.Either
|
import public Libraries.Control.Delayed
|
||||||
import Data.Nat
|
import public Libraries.Text.Bounded
|
||||||
import Data.Strings
|
|
||||||
|
|
||||||
%default total
|
%default total
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
module Libraries.Text.Parser
|
module Libraries.Text.Parser
|
||||||
|
|
||||||
import Libraries.Data.Bool.Extra
|
import Data.Bool
|
||||||
import Data.List
|
import Data.List
|
||||||
import Data.List1
|
import Data.List1
|
||||||
import Data.Nat
|
import Data.Nat
|
||||||
|
@ -1,7 +1,8 @@
|
|||||||
module Libraries.Text.Parser.Core
|
module Libraries.Text.Parser.Core
|
||||||
|
|
||||||
import Libraries.Data.Bool.Extra
|
import Data.Bool
|
||||||
import Data.List
|
import Data.List
|
||||||
|
|
||||||
import public Libraries.Control.Delayed
|
import public Libraries.Control.Delayed
|
||||||
import public Libraries.Text.Bounded
|
import public Libraries.Text.Bounded
|
||||||
|
|
||||||
|
@ -15,9 +15,9 @@ import TTImp.Elab.Check
|
|||||||
import TTImp.Elab.Delayed
|
import TTImp.Elab.Delayed
|
||||||
import TTImp.TTImp
|
import TTImp.TTImp
|
||||||
|
|
||||||
import Libraries.Data.Bool.Extra
|
|
||||||
import Data.List
|
import Data.List
|
||||||
import Data.Strings
|
import Data.Strings
|
||||||
|
|
||||||
import Libraries.Data.StringMap
|
import Libraries.Data.StringMap
|
||||||
|
|
||||||
%default covering
|
%default covering
|
||||||
@ -299,7 +299,7 @@ pruneByType env target alts
|
|||||||
let matches = mapMaybe id matches_in
|
let matches = mapMaybe id matches_in
|
||||||
logNF "elab.prune" 10 "Prune by" env target
|
logNF "elab.prune" 10 "Prune by" env target
|
||||||
log "elab.prune" 10 (show matches)
|
log "elab.prune" 10 (show matches)
|
||||||
res <- if anyTrue (map fst matches)
|
res <- if any Builtin.fst matches
|
||||||
-- if there's any concrete matches, drop the non-concrete
|
-- if there's any concrete matches, drop the non-concrete
|
||||||
-- matches marked as '%allow_overloads' from the possible set
|
-- matches marked as '%allow_overloads' from the possible set
|
||||||
then do keep <- filterCore (notOverloadable defs) matches
|
then do keep <- filterCore (notOverloadable defs) matches
|
||||||
|
@ -28,7 +28,6 @@ import TTImp.TTImp
|
|||||||
import TTImp.Unelab
|
import TTImp.Unelab
|
||||||
import TTImp.Utils
|
import TTImp.Utils
|
||||||
|
|
||||||
import Libraries.Data.Bool.Extra
|
|
||||||
import Data.Either
|
import Data.Either
|
||||||
import Data.List
|
import Data.List
|
||||||
|
|
||||||
@ -431,13 +430,13 @@ tryRecursive fc rig opts env ty topty rdata
|
|||||||
appsDiff : Term vs -> Term vs' -> List (Term vs) -> List (Term vs') ->
|
appsDiff : Term vs -> Term vs' -> List (Term vs) -> List (Term vs') ->
|
||||||
Bool
|
Bool
|
||||||
appsDiff (Ref _ (DataCon _ _) f) (Ref _ (DataCon _ _) f') args args'
|
appsDiff (Ref _ (DataCon _ _) f) (Ref _ (DataCon _ _) f') args args'
|
||||||
= f /= f' || anyTrue (zipWith argDiff args args')
|
= f /= f' || any (uncurry argDiff) (zip args args')
|
||||||
appsDiff (Ref _ (TyCon _ _) f) (Ref _ (TyCon _ _) f') args args'
|
appsDiff (Ref _ (TyCon _ _) f) (Ref _ (TyCon _ _) f') args args'
|
||||||
= f /= f' || anyTrue (zipWith argDiff args args')
|
= f /= f' || any (uncurry argDiff) (zip args args')
|
||||||
appsDiff (Ref _ _ f) (Ref _ _ f') args args'
|
appsDiff (Ref _ _ f) (Ref _ _ f') args args'
|
||||||
= f == f'
|
= f == f'
|
||||||
&& length args == length args'
|
&& length args == length args'
|
||||||
&& anyTrue (zipWith argDiff args args')
|
&& any (uncurry argDiff) (zip args args')
|
||||||
appsDiff (Ref _ (DataCon _ _) f) (Local _ _ _ _) _ _ = True
|
appsDiff (Ref _ (DataCon _ _) f) (Local _ _ _ _) _ _ = True
|
||||||
appsDiff (Local _ _ _ _) (Ref _ (DataCon _ _) f) _ _ = True
|
appsDiff (Local _ _ _ _) (Ref _ (DataCon _ _) f) _ _ = True
|
||||||
appsDiff f f' [] [] = argDiff f f'
|
appsDiff f f' [] [] = argDiff f f'
|
||||||
|
@ -2,11 +2,11 @@
|
|||||||
-- If we get more builtins it might be wise to move each builtin to it's own file.
|
-- If we get more builtins it might be wise to move each builtin to it's own file.
|
||||||
module TTImp.ProcessBuiltin
|
module TTImp.ProcessBuiltin
|
||||||
|
|
||||||
import Libraries.Data.Bool.Extra
|
|
||||||
import Data.Fin
|
import Data.Fin
|
||||||
import Libraries.Data.NameMap
|
|
||||||
import Data.List
|
import Data.List
|
||||||
|
|
||||||
|
import Libraries.Data.NameMap
|
||||||
|
|
||||||
import Core.CaseTree
|
import Core.CaseTree
|
||||||
import Core.Core
|
import Core.Core
|
||||||
import Core.Context
|
import Core.Context
|
||||||
@ -112,7 +112,7 @@ termConMatch : Term vs -> Term vs' -> Bool
|
|||||||
termConMatch (Local _ _ x _) (Local _ _ y _) = x == y
|
termConMatch (Local _ _ x _) (Local _ _ y _) = x == y
|
||||||
termConMatch (Ref _ _ n) (Ref _ _ m) = n == m
|
termConMatch (Ref _ _ n) (Ref _ _ m) = n == m
|
||||||
termConMatch (Meta _ _ i args0) (Meta _ _ j args1)
|
termConMatch (Meta _ _ i args0) (Meta _ _ j args1)
|
||||||
= i == j && allTrue (zipWith termConMatch args0 args1)
|
= i == j && all (uncurry termConMatch) (zip args0 args1)
|
||||||
-- I don't understand how they're equal if args are different lengths
|
-- I don't understand how they're equal if args are different lengths
|
||||||
-- but this is what's in Core.TT.
|
-- but this is what's in Core.TT.
|
||||||
termConMatch (Bind _ _ b s) (Bind _ _ c t) = eqBinderBy termConMatch b c && termConMatch s t
|
termConMatch (Bind _ _ b s) (Bind _ _ c t) = eqBinderBy termConMatch b c && termConMatch s t
|
||||||
|
Loading…
Reference in New Issue
Block a user