Last active
September 6, 2018 14:57
-
-
Save wuct/d81c24ce3fa5fe4de94e85bd12ddb0f6 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
foreign import kind Nat | |
foreign import kind Boolean | |
foreign import data Zero :: Nat | |
foreign import data Succ :: Nat → Nat | |
foreign import data True :: Boolean | |
foreign import data False :: Boolean | |
data NProxy (a :: Nat) = NProxy | |
data BProxy (b :: Boolean) = BProxy | |
type Two = Succ (Succ Zero) | |
type Three = Succ (Succ (Succ Zero)) | |
class IsEven (n :: Nat) (b :: Boolean) | n -> b | |
class IsOdd (n :: Nat) (b :: Boolean) | n -> b | |
instance isEvenZero :: IsEven Zero True | |
instance isEvenSucc :: IsOdd n b ⇒ IsEven (Succ n) b | |
instance isOddZero :: IsOdd Zero False | |
instance isOddSucc :: IsEven n b ⇒ IsOdd (Succ n) b | |
test3 :: BProxy True | |
test3 = BProxy :: ∀ b. IsEven Two b => BProxy b | |
-- Can't get compiled | |
-- test4 :: BProxy True | |
-- test4 = BProxy :: ∀ b. IsEven Three b => BProxy b |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment