If you read this blog, you know that I am very biased by having worked with unix shells for almost two decades and that I am addicted to the use of pipes (see e.g. Piping with Swift). I really find much more natural to see data moving from left to right.
Yesterday I was thinking that in Haskell everything is an expression and that you can easily define infix operators. Thus it must be possible to implement a shell-like pipe.
First of all, composition
(.) is too strong, the pipe I have in mind is like
($) but reversed. In fact, my second attempt (I feel embarassed by the first, I am not going to post it ;-P) was
($>) = flip ($)
One can immediately check that it is typed correctly as
($>) :: a -> (a -> b) -> b
Now I can do e.g.
import Data.List [3,1,4,2,2,6] $> sort $> filter (\x -> x < 4) $> map even $> and
and get the result without complaints.
This is just a stupid example but I find it more expressive (again probably because I use too much the shell) than
and . map even . filter (\x -> x < 4) . sort $ [3,1,4,2,2,6]
at least for certain kind of progressive filtering of data.
I am now following fp101x on edX. It is quite good! I will soon(?) post a brief cheatsheet that I made to recall how to use Functors, Monads and other interesting constructs.