Neil Sculthorpe • Jan Bracker • George Giorgidze • Andy Gill
Proceedings of the 18th International Conference on Functional Programming (ICFP 2013), Boston, Massachusetts, USA. ACM, 2013.
In Haskell, there are many data types that would form monads were it not for the presence of type-class constraints on the operations on that data type. This is a frustrating problem in practice, because there is a considerable amount of support and infrastructure for monads that these data types cannot use. Using several examples, we show that a monadic computation can be restructured into a normal form such that the standard monad class can be used. The technique is not speciﬁc to monads, and we show how it can also be applied to other structures, such as applicative functors. One signiﬁcant use case for this technique is domain-speciﬁc languages, where it is often desirable to compile a deep embedding of a computation to some other language, which requires restricting the types that can appear in that computation.