mirror of
https://github.com/anoma/juvix.git
synced 2024-12-24 07:57:58 +03:00
[ Core ] reviewed Eq and added Ord instance for Quantity.
This commit is contained in:
parent
69330ed4f4
commit
d62daccc41
@ -15,4 +15,11 @@ Also,
|
||||
needed.
|
||||
- top vs. local scope.
|
||||
- On equality type-checking, see [abstract](https://github.com/anjapetkovic/anjapetkovic.github.io/blob/master/talks/2021-06-17-TYPES2021/abstract.pdf)
|
||||
- To document the code, see https://kowainik.github.io/posts/haddock-tips
|
||||
- To document the code, see https://kowainik.github.io/posts/haddock-tips
|
||||
|
||||
Initial task order for Minijuvix indicated between parenthesis:
|
||||
1. Parser (3.)
|
||||
2. Typechecker (1.)
|
||||
3. Compiler (2.)
|
||||
4. Interpreter (4.)
|
||||
|
||||
|
@ -39,28 +39,30 @@ instance
|
||||
|
||||
instance
|
||||
-- TODO: this must be defined using copatterns or a top-level record.
|
||||
-- QuantityOrd : Ord Quantity
|
||||
-- QuantityOrd = ordFromCompare λ where
|
||||
-- Zero Zero → EQ
|
||||
-- Zero _ → LT
|
||||
-- _ Zero → GT
|
||||
-- One One → EQ
|
||||
-- One _ → LT
|
||||
-- _ One → GT
|
||||
-- Many Many → EQ
|
||||
QuantityOrd : Ord Quantity
|
||||
QuantityOrd = ordFromCompare
|
||||
λ {
|
||||
Zero Zero → EQ;
|
||||
Zero _ → LT;
|
||||
_ Zero → GT;
|
||||
One One → EQ;
|
||||
One _ → LT;
|
||||
_ One → GT;
|
||||
Many Many → EQ
|
||||
}
|
||||
|
||||
QuantitySGroup : Semigroup Quantity
|
||||
QuantitySGroup ._<>_ Zero _ = Zero
|
||||
QuantitySGroup ._<>_ One m = m
|
||||
QuantitySGroup ._<>_ Many Zero = Zero
|
||||
QuantitySGroup ._<>_ Many One = Many
|
||||
QuantitySGroup ._<>_ Many Many = Many
|
||||
QuantitySemigroup : Semigroup Quantity
|
||||
QuantitySemigroup ._<>_ Zero _ = Zero
|
||||
QuantitySemigroup ._<>_ One m = m
|
||||
QuantitySemigroup ._<>_ Many Zero = Zero
|
||||
QuantitySemigroup ._<>_ Many One = Many
|
||||
QuantitySemigroup ._<>_ Many Many = Many
|
||||
|
||||
QuantityMon : Monoid Quantity
|
||||
QuantityMon .mempty = Zero
|
||||
|
||||
-- {-# COMPILE AGDA2HS QuantityOrd #-}
|
||||
{-# COMPILE AGDA2HS QuantitySGroup #-}
|
||||
{-# COMPILE AGDA2HS QuantitySemigroup #-}
|
||||
{-# COMPILE AGDA2HS QuantityMon #-}
|
||||
|
||||
--------------------------------------------------------------------------------
|
||||
@ -164,7 +166,9 @@ data CheckableTerm where
|
||||
--------------------------------------------------------------------------------
|
||||
|
||||
data InferableTerm where
|
||||
-- | Variables, typing rule Var⇒.
|
||||
-- | Variables, typing rule Var⇒. The separation for a variable
|
||||
-- between Bound and Free is due to McBride and McKinna in
|
||||
-- "Functional Pearl: I am not a Number—I am a Free Variable".
|
||||
Bound : Nat → InferableTerm
|
||||
Free : Name → InferableTerm
|
||||
-- | Annotations, typing rule Ann⇒.
|
||||
@ -262,7 +266,9 @@ data Term : Set where
|
||||
{-# COMPILE AGDA2HS Term #-}
|
||||
|
||||
termEq : Term → Term → Bool
|
||||
termEq (Checkable (Inferred x)) (Inferable y) = x == y
|
||||
termEq (Checkable x) (Checkable y) = x == y
|
||||
termEq (Inferable x) (Checkable (Inferred y)) = x == y
|
||||
termEq (Inferable x) (Inferable y) = x == y
|
||||
termEq _ _ = false
|
||||
{-# COMPILE AGDA2HS termEq #-}
|
||||
@ -271,4 +277,4 @@ instance
|
||||
TermEq : Eq Term
|
||||
TermEq ._==_ = termEq
|
||||
|
||||
{-# COMPILE AGDA2HS TermEq #-}
|
||||
{-# COMPILE AGDA2HS TermEq #-}
|
@ -99,7 +99,9 @@ data Term = Checkable CheckableTerm
|
||||
| Inferable InferableTerm
|
||||
|
||||
termEq :: Term -> Term -> Bool
|
||||
termEq (Checkable (Inferred x)) (Inferable y) = x == y
|
||||
termEq (Checkable x) (Checkable y) = x == y
|
||||
termEq (Inferable x) (Checkable (Inferred y)) = x == y
|
||||
termEq (Inferable x) (Inferable y) = x == y
|
||||
termEq _ _ = False
|
||||
|
||||
|
@ -98,6 +98,7 @@ valueToTerm v = Checkable Unit -- TODO
|
||||
|
||||
--------------------------------------------------------------------------------
|
||||
-- Substitution. (see Def. 12 in Conor's paper to see where subst is needed.)
|
||||
-- See a relevant discussion on ekmett/bound-making-de-bruijn-succ-less.
|
||||
--------------------------------------------------------------------------------
|
||||
|
||||
substCheckableTerm
|
||||
|
Loading…
Reference in New Issue
Block a user