{-# LANGUAGE Safe #-}
module Relude.Extra.Foldable
( foldlSC
) where
import Relude
foldlSC :: forall t b a. Foldable t => (b -> a -> Either b b) -> b -> t a -> b
foldlSC :: (b -> a -> Either b b) -> b -> t a -> b
foldlSC f :: b -> a -> Either b b
f = (t a -> b -> b) -> b -> t a -> b
forall a b c. (a -> b -> c) -> b -> a -> c
flip ((t a -> b -> b) -> b -> t a -> b)
-> (t a -> b -> b) -> b -> t a -> b
forall a b. (a -> b) -> a -> b
$ (a -> (b -> b) -> b -> b) -> (b -> b) -> t a -> b -> b
forall (t :: * -> *) a b.
Foldable t =>
(a -> b -> b) -> b -> t a -> b
foldr a -> (b -> b) -> b -> b
go b -> b
forall a. a -> a
id
where
go :: a -> (b -> b) -> b -> b
go :: a -> (b -> b) -> b -> b
go x :: a
x k :: b -> b
k z :: b
z = case b -> a -> Either b b
f b
z a
x of
Left l :: b
l -> b
l
Right r :: b
r -> b -> b
k b
r
{-# INLINE foldlSC #-}