So are you suggesting that we add these to Data.Foldable?
headMay = foldr (\x _ -> Just x) Nothing
lastMay = foldl (\_ x -> Just x) NothingOn Feb 26, 2015 9:18 AM, "Petr Pudlák" <petr.mvd@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 addheadMaybe :: (Foldable t) => t a -> Maybe aheadMaybe = getFirst . foldMap (First . Just)and similarly lastMaybe to Data.Foldable.Thanks,Petr_______________________________________________
Haskell-Cafe mailing list
Haskell-Cafe@haskell.org
http://mail.haskell.org/cgi-bin/mailman/listinfo/haskell-cafe