[Haskell-cafe] safe ways how to get head/last of Seq (or Foldable in general)

Michael Snoyman michael at snoyman.com
Thu Feb 26 14:26:08 UTC 2015


The mono-traversable package provides headMay[1] which works for Seq.

[1]
http://www.stackage.org/haddock/nightly-2015-02-25/mono-traversable-0.9.0.1/Data-MonoTraversable.html#v:headMay

On Thu Feb 26 2015 at 4:18:31 PM Petr Pudlák <petr.mvd at gmail.com> wrote:

> Hi,
>
> today I was a bit surprised that apparently there is no easy way how to
> safely get the head element of `Seq` in a point-free way. Of course there
> is `viewl`, but it seems the data type has no folding function (something
> like 'foldViewL :: b -> (a -> Seq a -> b) -> b`.
>
> Is there any existing function like `Seq a -> Maybe a` to safely retrieve
> the head (or last) element?
>
> If not, I'd suggest to add
>
>     headMaybe :: (Foldable t) => t a -> Maybe a
>     headMaybe = getFirst . foldMap (First . Just)
>
> and similarly lastMaybe to Data.Foldable.
>
>   Thanks,
>   Petr
> _______________________________________________
> Haskell-Cafe mailing list
> Haskell-Cafe at haskell.org
> http://mail.haskell.org/cgi-bin/mailman/listinfo/haskell-cafe
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.haskell.org/pipermail/haskell-cafe/attachments/20150226/74e55e99/attachment.html>


More information about the Haskell-Cafe mailing list