blob: e91fe35e77d6aca4d110cd86eb26a8c7da59bf0a (
plain)
1
2
3
4
5
6
7
8
9
|
import nat
data Array : Type -> Nat -> Type where
Empty : (A:Type) -> Array A Zero
Cell : (A:Type) -> (n:Nat) -> A -> Array A n -> Array A (Succ n)
mapA : (A:Type) -> (B:Type) -> (n:Nat) -> (A -> B) -> Array A n -> Array B n
mapA A B _ f (Empty _) = Empty B
mapA A B (Succ n) f (Cell _ _ x xs) = Cell B n (f x) (mapA A B n f xs)
|