Book Image

Haskell Cookbook

Book Image

Haskell Cookbook

Overview of this book

Haskell is a purely functional language that has the great ability to develop large and difficult, but easily maintainable software. Haskell Cookbook provides recipes that start by illustrating the principles of functional programming in Haskell, and then gradually build up your expertise in creating industrial-strength programs to accomplish any goal. The book covers topics such as Functors, Applicatives, Monads, and Transformers. You will learn various ways to handle state in your application and explore advanced topics such as Generalized Algebraic Data Types, higher kind types, existential types, and type families. The book will discuss the association of lenses with type classes such as Functor, Foldable, and Traversable to help you manage deep data structures. With the help of the wide selection of examples in this book, you will be able to upgrade your Haskell programming skills and develop scalable software idiomatically.
Table of Contents (13 chapters)

Introduction

In the previous chapter, we looked at Functor, Applicative, and monads. In this chapter, we will look at State Monad, a monad where we can store a state and modify it. Once we understand monad, we will understand that we can implement a monad (or an Applicative) for a specific purpose.

It is very likely that a situation will arise where we would like to combine two monads to make a single monad. For example, consider a parser monad, Parser a and a State Monad State s a (where s is the state and a is the output of the parser). If we also would like to maintain a state along with the parsing output, then we can combine them together with Parser (State s a). With this, now, we can either operate in the outer Parser monad or internal State s a monad.

Let's take an example of IO monad with Maybe:

    foo :: IO (Maybe Int)
foo = Just 10

bar :: IO (Maybe Int...