blob: f946e891201fa9273760cfab8f5af1171ddb933b (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
{-# LANGUAGE TypeFamilies #-}
module Main where
type family Elem c
class Col c where
isEmpty :: c -> Bool
add :: c -> Elem c -> c
headTail :: c -> (Elem c,c)
-- LIST
instance Col [a] where
isEmpty = null
add = flip (:)
headTail (x:xs) = (x,xs)
type instance Elem [a] = a
-- SEQUENCE
data Sequence a = Nil | Snoc (Sequence a) a deriving Show
instance Col (Sequence a) where
isEmpty Nil = True
isEmpty _ = False
add s x = Snoc s x
headTail (Snoc s x) = (x,s)
type instance Elem (Sequence a) = a
--
addAll c1 c2
| isEmpty c1
= c2
| otherwise
= let (x,c1') = headTail c1
in addAll c1' (add c2 x)
--
main = print $ addAll c1 c2
where c1 = ['a','b','c']
c2 = (Snoc (Snoc (Snoc Nil 'd') 'e') 'f')
|