aboutsummaryrefslogtreecommitdiff
path: root/ch06_06.4-i_ii_iii.hs
diff options
context:
space:
mode:
authorPaul Oliver <contact@pauloliver.dev>2025-01-03 11:01:20 -0800
committerPaul Oliver <contact@pauloliver.dev>2025-01-05 09:59:10 -0800
commit6a0d7f5c434c3564d0119befb6799fd77581050a (patch)
treef20bc998290211d2a895523417ad32e297b31af0 /ch06_06.4-i_ii_iii.hs
InitialHEADmaster
Diffstat (limited to 'ch06_06.4-i_ii_iii.hs')
-rw-r--r--ch06_06.4-i_ii_iii.hs42
1 files changed, 42 insertions, 0 deletions
diff --git a/ch06_06.4-i_ii_iii.hs b/ch06_06.4-i_ii_iii.hs
new file mode 100644
index 0000000..13a4fa3
--- /dev/null
+++ b/ch06_06.4-i_ii_iii.hs
@@ -0,0 +1,42 @@
+newtype Cont a = Cont
+ { unCont :: forall r. (a -> r) -> r
+ }
+
+-- I could not figure out `Functor`. After peeking Sandy's solution I was able
+-- to figure out `Applicative`, but failed miserably with `Monad`. I added
+-- annotations on the types of all the terms on my attempt to figure it out.
+
+-- Exercise 6.4-i
+-- Provide a `Functor` instance for `Cont`.
+instance Functor Cont where
+ -- fmap :: (a -> b) -> Cont a -> Cont b
+ -- f :: a -> b
+ -- a :: (a -> r) -> r
+ -- c :: b -> r
+ -- c . f :: a -> r
+ -- a $ c . f :: r
+ fmap f (Cont a) = Cont $ \c -> a $ c . f
+
+-- Exercise 6.4-ii
+-- Provide a `Applicative` instances for `Cont`.
+instance Applicative Cont where
+ pure a = Cont $ \c -> c a
+
+ -- (<*>) :: Cont (a -> b) -> Cont a -> Cont b
+ -- f :: ((a -> b) -> r) -> r
+ -- a :: (a -> r) -> r
+ -- c :: b -> r
+ -- c' :: a -> b
+ Cont f <*> Cont a = Cont $ \c -> f $ \c' -> a $ c . c'
+
+-- Exercise 6.4-iii
+-- Provide a `Monad` instances for `Cont`.
+instance Monad Cont where
+ -- (>>=) :: Cont a -> (a -> Cont b) -> Cont b
+ -- a :: (a -> r) -> r
+ -- b :: (b -> r) -> r
+ -- f :: a -> Cont b
+ -- unCont . f :: a -> (b -> r) -> r
+ -- c :: b -> r
+ -- c' :: a
+ Cont a >>= f = Cont $ \c -> a $ \c' -> unCont (f c') c