Suppose I have a function with the following type signature:
g :: a -> a -> a -> b
I also have a list of a
s—let's call it xs
—that I know will contain at least three items. I'd like to apply g
to the first three items of xs
. I know I could define a combinator like the following:
($$$) :: (a -> a -> a -> b) -> [a] -> b
f $$$ (x:y:z:_) = f x y z
Then I could just use g $$$ xs
. This makes $$$
a bit like uncurry
, but for a function with three arguments of the same type and a list instead of a tuple.
Is there a way to do this idiomatically using standard combinators? Or rather, what's the most idiomatic way to do this in Haskell? I thought trying pointfree
on a non-infix version of $$$
might give me some idea of where to start, but the output was an abomination with 10 flip
s, a handful of head
s and tail
s and ap
s, and 28 parentheses.
(NB: I know this isn't a terribly Haskelly thing to do in the first place, but I've come across a couple of situations where it seems like a reasonable solution, especially when using Parsec. I'll certainly accept "don't ever do this in real code" if that's the best answer, but I'd prefer to see some clever trick involving the ((->) r)
monad or whatever.)