
Near as I can tell, this is basically having to do with partial application
and the order of precedence for the (.) operator. A great way to look at
this stuff is using the :t command in GHCi and checking out the types
involved.
Prelude> :t (.)
(.) :: (b -> c) -> (a -> b) -> a -> c
Prelude> :t last
last :: [a] -> a
Prelude> :t (last .)
(last .) :: (a -> [c]) -> a -> c
Looking back at the type for (.) and plugging in "[a]" in place of "b" and
"a" in place of "c" we get:
([b] -> b) -> (a -> [b]) -> a -> b
and since "last" takes the place of the first function we can reduce that
to:
(a -> [b]) -> a -> b
GHCi used "c" where we used "b" but you can clearly see the signatures are
identical other than that detail.
What we're left with is, (last .) is used to take a function from some type
"a" that returns a list of type "b", and a "a" value, and then returns the
last value from that list of "b" types.
-R. Kyle Murphy
--
Curiosity was framed, Ignorance killed the cat.
On Wed, Apr 30, 2014 at 11:29 AM, Gilberto Melfe
Hello everybody !
Could someone explain me exactly how this function works?
elementAt_w'pf = (last .) . take . (+ 1)
It's a posted solution to: 99 Haskell problems, problem 3.
I'm having trouble with the "(last .) ." thing!
Hope someone can help!
Thank You!
Gilberto
_______________________________________________ Beginners mailing list Beginners@haskell.org http://www.haskell.org/mailman/listinfo/beginners