summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorbringert <bringert@cs.chalmers.se>2005-11-29 19:43:00 +0000
committerbringert <bringert@cs.chalmers.se>2005-11-29 19:43:00 +0000
commit9db05c57f8b65cab64223d27510df620a9fcd0ad (patch)
tree2168a10e58b26c3872241b5e5e8b7775b6ee809f
parentd0d110ed6a75d09876005aa46999b6cacaaa22c7 (diff)
Added example of composOp overloading to overload.tr.
-rw-r--r--transfer/examples/overload.tr31
1 files changed, 26 insertions, 5 deletions
diff --git a/transfer/examples/overload.tr b/transfer/examples/overload.tr
index cb3862d7a..32d617d28 100644
--- a/transfer/examples/overload.tr
+++ b/transfer/examples/overload.tr
@@ -1,5 +1,8 @@
+Monoid : Type -> Type
+Monoid A = sig { zero : A; plus : A -> A -> A }
+
Additive : Type -> Type
-Additive A = sig { zero : A; plus : A -> A -> A }
+Additive = Monoid
additive_Integer : Additive Integer
additive_Integer = rec { zero = 0; plus = prim_add_Int }
@@ -8,9 +11,27 @@ sum : (A:Type) -> Additive A -> List A -> A
sum _ d (Nil _) = d.zero
sum A d (Cons _ x xs) = d.plus x (sum A d xs)
-Showable : Type -> Type
-Showable A = sig { show : A -> String }
---Compositional : Type -> Type
---Compositional A = { composOp : } \ No newline at end of file
+
+Show : Type -> Type
+Show A = sig { show : A -> String }
+
+show : (A : Type) -> Show A -> A -> String
+show _ rec{show = show} x = show x
+
+
+
+
+
+
+Compos : (C : Type) -> (C -> Type) -> Type
+Compos C T = sig
+ composOp : (c : C) -> ((d : C) -> T d -> T d) -> T c -> T c
+ composFold : (B : Type) -> Monoid B -> (c : C) -> ((d : C) -> T d -> b) -> T c -> b
+
+composOp : (T : Type) -> (C : Type) -> Compos C T -> (c : C) -> ((d : C) -> T d -> T d) -> T c -> T c
+composOp _ _ rec{composOp=composOp} c f t = composOp c f t
+
+composFold : (T : Type) -> (C : Type) -> Compos C T -> (B : Type) -> Monoid B -> ((d : C) -> T d -> b) -> T c -> b
+composFold _ _ rec{composFold=composFold} b m c f t = composFold b m c f t \ No newline at end of file