summaryrefslogtreecommitdiff
path: root/transfer/lib/bintree.tra
diff options
context:
space:
mode:
authorbringert <bringert@cs.chalmers.se>2006-03-20 14:46:47 +0000
committerbringert <bringert@cs.chalmers.se>2006-03-20 14:46:47 +0000
commiteacb437f437bc79650708af472b7796c7fd041e5 (patch)
tree44d21f05cf6ea4f6a52c819488a31521ad6d22d7 /transfer/lib/bintree.tra
parentd760ce973896bbfd5e9f62516bb953cfeeabaf1a (diff)
Expermintation woth a collections framework for transfer.
Diffstat (limited to 'transfer/lib/bintree.tra')
-rw-r--r--transfer/lib/bintree.tra22
1 files changed, 22 insertions, 0 deletions
diff --git a/transfer/lib/bintree.tra b/transfer/lib/bintree.tra
new file mode 100644
index 000000000..0dd21f184
--- /dev/null
+++ b/transfer/lib/bintree.tra
@@ -0,0 +1,22 @@
+-- NOTE: this is unfinished and untested
+
+import prelude
+
+data BinTree : Type -> Type where
+ Leaf : (A:Type) -> BinTree A
+ Node : (A:Type) -> BinTree A -> A -> BinTree A -> BinTree A
+
+contains : (A:Type) -> Ord A -> A -> BinTree A -> Bool
+contains _ _ _ (Leaf _) = False
+contains A o x (Node _ l y r)
+ | x < y = contains A o x l
+ | x > y = contains A o x r
+ | otherwise = True
+
+insert : (A:Type) -> Ord A -> A -> BinTree A -> BinTree A
+insert A o x (Leaf _) = Node A (Leaf A) x (Leaf A)
+insert A o x (Node _ l y r)
+ | x < y = Node A (insert A o x l) y r
+ | x > y = Node A l y (insert A o x r)
+ | otherwise = Node A l x r
+