{-# LANGUAGE ConstrainedClassMethods #-}
{-# LANGUAGE CPP #-}
{-# LANGUAGE DefaultSignatures #-}
{-# LANGUAGE DerivingStrategies #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE TypeOperators #-}
{-# LANGUAGE UndecidableInstances #-}
{-# LANGUAGE GeneralizedNewtypeDeriving #-}
module Data.MonoTraversable where
import Control.Applicative
import Control.Category
import Control.Monad (Monad (..))
import qualified Data.ByteString as S
import qualified Data.ByteString.Lazy as L
import qualified Data.Foldable as F
import Data.Functor
import Data.Maybe (fromMaybe)
import Data.Monoid (Monoid (..), Any (..), All (..))
import Data.Proxy
import qualified Data.Text as T
import qualified Data.Text.Lazy as TL
import Data.Traversable
import Data.Word (Word8)
import Data.Int (Int, Int64)
import GHC.Exts (build)
import GHC.Generics ((:.:), (:*:), (:+:)(..), K1(..), M1(..), Par1(..), Rec1(..), U1(..), V1)
import Prelude (Bool (..), const, Char, flip, IO, Maybe (..), Either (..),
(+), Integral, Ordering (..), compare, fromIntegral, Num, (>=),
(==), seq, otherwise, Eq, Ord, (-), (*))
import qualified Prelude
import qualified Data.ByteString.Internal as Unsafe
import qualified Foreign.ForeignPtr.Unsafe as Unsafe
import Foreign.Ptr (plusPtr)
import Foreign.ForeignPtr (touchForeignPtr)
import Foreign.Storable (peek)
import Control.Arrow (Arrow)
import Data.Tree (Tree (..))
import Data.Sequence (Seq, ViewL (..), ViewR (..))
import qualified Data.Sequence as Seq
import Data.IntMap (IntMap)
import Data.IntSet (IntSet)
import qualified Data.List as List
import Data.List.NonEmpty (NonEmpty)
import Data.Functor.Identity (Identity)
import Data.Map (Map)
import qualified Data.Map.Strict as Map
import Data.HashMap.Strict (HashMap)
import Data.Vector (Vector)
import Control.Monad.Trans.Maybe (MaybeT (..))
#if !MIN_VERSION_transformers(0,6,0)
import Control.Monad.Trans.List (ListT)
#endif
import Control.Monad.Trans.Writer (WriterT)
import qualified Control.Monad.Trans.Writer.Strict as Strict (WriterT)
import Control.Monad.Trans.State (StateT(..))
import qualified Control.Monad.Trans.State.Strict as Strict (StateT(..))
import Control.Monad.Trans.RWS (RWST(..))
import qualified Control.Monad.Trans.RWS.Strict as Strict (RWST(..))
import Control.Monad.Trans.Reader (ReaderT)
import Control.Monad.Trans.Cont (ContT)
import Data.Functor.Compose (Compose)
import Data.Functor.Product (Product)
import Data.Set (Set)
import qualified Data.Set as Set
import Data.HashSet (HashSet)
import qualified Data.HashSet as HashSet
import Data.Hashable (Hashable)
import qualified Data.Vector as V
import qualified Data.Vector.Unboxed as U
import qualified Data.Vector.Storable as VS
import qualified Data.IntSet as IntSet
import Data.Semigroup
( Semigroup
#if !MIN_VERSION_base(4,16,0)
, Option (..)
#endif
, Arg
)
import qualified Data.ByteString.Unsafe as SU
import Control.Monad.Trans.Identity (IdentityT)
type family Element mono
type instance Element S.ByteString = Word8
type instance Element L.ByteString = Word8
type instance Element T.Text = Char
type instance Element TL.Text = Char
type instance Element [a] = a
type instance Element (IO a) = a
type instance Element (ZipList a) = a
type instance Element (Maybe a) = a
type instance Element (Tree a) = a
type instance Element (Seq a) = a
type instance Element (ViewL a) = a
type instance Element (ViewR a) = a
type instance Element (IntMap a) = a
type instance Element IntSet = Int
#if !MIN_VERSION_base(4,16,0)
type instance Element (Option a) = a
#endif
type instance Element (NonEmpty a) = a
type instance Element (Identity a) = a
type instance Element (r -> a) = a
type instance Element (Either a b) = b
type instance Element (a, b) = b
type instance Element (Const m a) = a
type instance Element (WrappedMonad m a) = a
type instance Element (Map k v) = v
type instance Element (HashMap k v) = v
type instance Element (Set e) = e
type instance Element (HashSet e) = e
type instance Element (Vector a) = a
type instance Element (WrappedArrow a b c) = c
type instance Element (MaybeT m a) = a
#if !MIN_VERSION_transformers(0,6,0)
type instance Element (ListT m a) = a
#endif
type instance Element (IdentityT m a) = a
type instance Element (WriterT w m a) = a
type instance Element (Strict.WriterT w m a) = a
type instance Element (StateT s m a) = a
type instance Element (Strict.StateT s m a) = a
type instance Element (RWST r w s m a) = a
type instance Element (Strict.RWST r w s m a) = a
type instance Element (ReaderT r m a) = a
type instance Element (ContT r m a) = a
type instance Element (Compose f g a) = a
type instance Element (Product f g a) = a
type instance Element (U.Vector a) = a
type instance Element (VS.Vector a) = a
type instance Element (Arg a b) = b
type instance Element ((f :.: g) a) = a
type instance Element ((f :*: g) a) = a
type instance Element ((f :+: g) a) = a
type instance Element (K1 i c a) = a
type instance Element (M1 i c f a) = a
type instance Element (Rec1 f a) = a
type instance Element (Par1 a) = a
type instance Element (U1 a) = a
type instance Element (V1 a) = a
type instance Element (Proxy a) = a
class MonoFunctor mono where
omap :: (Element mono -> Element mono) -> mono -> mono
default omap :: (Functor f, Element (f a) ~ a, f a ~ mono)
=> (Element mono -> Element mono) -> mono -> mono
omap = forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap
{-# INLINE omap #-}
instance MonoFunctor S.ByteString where
omap :: (Element ByteString -> Element ByteString)
-> ByteString -> ByteString
omap = (Word8 -> Word8) -> ByteString -> ByteString
S.map
{-# INLINE omap #-}
instance MonoFunctor L.ByteString where
omap :: (Element ByteString -> Element ByteString)
-> ByteString -> ByteString
omap = (Word8 -> Word8) -> ByteString -> ByteString
L.map
{-# INLINE omap #-}
instance MonoFunctor T.Text where
omap :: (Element Text -> Element Text) -> Text -> Text
omap = (Char -> Char) -> Text -> Text
T.map
{-# INLINE omap #-}
instance MonoFunctor TL.Text where
omap :: (Element Text -> Element Text) -> Text -> Text
omap = (Char -> Char) -> Text -> Text
TL.map
{-# INLINE omap #-}
instance MonoFunctor [a]
instance MonoFunctor (IO a)
instance MonoFunctor (ZipList a)
instance MonoFunctor (Maybe a)
instance MonoFunctor (Tree a)
instance MonoFunctor (Seq a)
instance MonoFunctor (ViewL a)
instance MonoFunctor (ViewR a)
instance MonoFunctor (IntMap a)
#if !MIN_VERSION_base(4,16,0)
instance MonoFunctor (Option a)
#endif
instance MonoFunctor (NonEmpty a)
instance MonoFunctor (Identity a)
instance MonoFunctor (r -> a)
instance MonoFunctor (Either a b)
instance MonoFunctor (a, b)
instance MonoFunctor (Const m a)
instance Monad m => MonoFunctor (WrappedMonad m a)
instance MonoFunctor (Map k v)
instance MonoFunctor (HashMap k v)
instance MonoFunctor (Vector a)
instance MonoFunctor (Arg a b)
instance Arrow a => MonoFunctor (WrappedArrow a b c)
instance Functor m => MonoFunctor (MaybeT m a)
#if !MIN_VERSION_transformers(0,6,0)
instance Functor m => MonoFunctor (ListT m a)
#endif
instance Functor m => MonoFunctor (IdentityT m a)
instance Functor m => MonoFunctor (WriterT w m a)
instance Functor m => MonoFunctor (Strict.WriterT w m a)
instance Functor m => MonoFunctor (StateT s m a)
instance Functor m => MonoFunctor (Strict.StateT s m a)
instance Functor m => MonoFunctor (RWST r w s m a)
instance Functor m => MonoFunctor (Strict.RWST r w s m a)
instance Functor m => MonoFunctor (ReaderT r m a)
instance Functor m => MonoFunctor (ContT r m a)
instance (Functor f, Functor g) => MonoFunctor (Compose f g a)
instance (Functor f, Functor g) => MonoFunctor (Product f g a)
instance (Functor f, Functor g) => MonoFunctor ((f :.: g) a)
instance (Functor f, Functor g) => MonoFunctor ((f :*: g) a)
instance (Functor f, Functor g) => MonoFunctor ((f :+: g) a)
instance MonoFunctor (K1 i c a)
instance Functor f => MonoFunctor (M1 i c f a)
instance Functor f => MonoFunctor (Rec1 f a)
instance MonoFunctor (Par1 a)
instance MonoFunctor (U1 a)
instance MonoFunctor (V1 a)
instance MonoFunctor (Proxy a)
instance U.Unbox a => MonoFunctor (U.Vector a) where
omap :: (Element (Vector a) -> Element (Vector a)) -> Vector a -> Vector a
omap = forall a b. (Unbox a, Unbox b) => (a -> b) -> Vector a -> Vector b
U.map
{-# INLINE omap #-}
instance VS.Storable a => MonoFunctor (VS.Vector a) where
omap :: (Element (Vector a) -> Element (Vector a)) -> Vector a -> Vector a
omap = forall a b.
(Storable a, Storable b) =>
(a -> b) -> Vector a -> Vector b
VS.map
{-# INLINE omap #-}
replaceElem :: (MonoFunctor mono, Eq (Element mono)) => Element mono -> Element mono -> mono -> mono
replaceElem :: forall mono.
(MonoFunctor mono, Eq (Element mono)) =>
Element mono -> Element mono -> mono -> mono
replaceElem Element mono
old Element mono
new = forall mono.
MonoFunctor mono =>
(Element mono -> Element mono) -> mono -> mono
omap (\Element mono
x -> if Element mono
x forall a. Eq a => a -> a -> Bool
== Element mono
old then Element mono
new else Element mono
x)
{-# INLINE [0] replaceElem #-}
{-# RULES "strict Text replaceElem" replaceElem = replaceElemStrictText #-}
replaceElemStrictText :: Char -> Char -> T.Text -> T.Text
replaceElemStrictText :: Char -> Char -> Text -> Text
replaceElemStrictText Char
old Char
new = Text -> Text -> Text -> Text
T.replace (Char -> Text
T.singleton Char
old) (Char -> Text
T.singleton Char
new)
{-# RULES "lazy Text replaceElem" replaceElem = replaceElemLazyText #-}
replaceElemLazyText :: Char -> Char -> TL.Text -> TL.Text
replaceElemLazyText :: Char -> Char -> Text -> Text
replaceElemLazyText Char
old Char
new = Text -> Text -> Text -> Text
TL.replace (Char -> Text
TL.singleton Char
old) (Char -> Text
TL.singleton Char
new)
class MonoFoldable mono where
ofoldMap :: Monoid m => (Element mono -> m) -> mono -> m
default ofoldMap :: (t a ~ mono, a ~ Element (t a), F.Foldable t, Monoid m) => (Element mono -> m) -> mono -> m
ofoldMap = forall (t :: * -> *) m a.
(Foldable t, Monoid m) =>
(a -> m) -> t a -> m
F.foldMap
{-# INLINE ofoldMap #-}
ofoldr :: (Element mono -> b -> b) -> b -> mono -> b
default ofoldr :: (t a ~ mono, a ~ Element (t a), F.Foldable t) => (Element mono -> b -> b) -> b -> mono -> b
ofoldr = forall (t :: * -> *) a b.
Foldable t =>
(a -> b -> b) -> b -> t a -> b
F.foldr
{-# INLINE ofoldr #-}
ofoldl' :: (a -> Element mono -> a) -> a -> mono -> a
default ofoldl' :: (t b ~ mono, b ~ Element (t b), F.Foldable t) => (a -> Element mono -> a) -> a -> mono -> a
ofoldl' = forall (t :: * -> *) b a.
Foldable t =>
(b -> a -> b) -> b -> t a -> b
F.foldl'
{-# INLINE ofoldl' #-}
otoList :: mono -> [Element mono]
otoList mono
t = forall a. (forall b. (a -> b -> b) -> b -> b) -> [a]
build (\ Element mono -> b -> b
mono b
n -> forall mono b.
MonoFoldable mono =>
(Element mono -> b -> b) -> b -> mono -> b
ofoldr Element mono -> b -> b
mono b
n mono
t)
{-# INLINE otoList #-}
oall :: (Element mono -> Bool) -> mono -> Bool
oall Element mono -> Bool
f = All -> Bool
getAll forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono m.
(MonoFoldable mono, Monoid m) =>
(Element mono -> m) -> mono -> m
ofoldMap (Bool -> All
All forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. Element mono -> Bool
f)
{-# INLINE oall #-}
oany :: (Element mono -> Bool) -> mono -> Bool
oany Element mono -> Bool
f = Any -> Bool
getAny forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono m.
(MonoFoldable mono, Monoid m) =>
(Element mono -> m) -> mono -> m
ofoldMap (Bool -> Any
Any forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. Element mono -> Bool
f)
{-# INLINE oany #-}
onull :: mono -> Bool
onull = forall mono.
MonoFoldable mono =>
(Element mono -> Bool) -> mono -> Bool
oall (forall a b. a -> b -> a
const Bool
False)
{-# INLINE onull #-}
olength :: mono -> Int
olength = forall mono a.
MonoFoldable mono =>
(a -> Element mono -> a) -> a -> mono -> a
ofoldl' (\Int
i Element mono
_ -> Int
i forall a. Num a => a -> a -> a
+ Int
1) Int
0
{-# INLINE olength #-}
olength64 :: mono -> Int64
olength64 = forall mono a.
MonoFoldable mono =>
(a -> Element mono -> a) -> a -> mono -> a
ofoldl' (\Int64
i Element mono
_ -> Int64
i forall a. Num a => a -> a -> a
+ Int64
1) Int64
0
{-# INLINE olength64 #-}
ocompareLength :: Integral i => mono -> i -> Ordering
ocompareLength mono
c0 i
i0 = forall mono. MonoFoldable mono => mono -> Int
olength mono
c0 forall a. Ord a => a -> a -> Ordering
`compare` forall a b. (Integral a, Num b) => a -> b
fromIntegral i
i0
{-# INLINE ocompareLength #-}
otraverse_ :: Applicative f => (Element mono -> f b) -> mono -> f ()
otraverse_ Element mono -> f b
f = forall mono b.
MonoFoldable mono =>
(Element mono -> b -> b) -> b -> mono -> b
ofoldr (forall (f :: * -> *) a b. Applicative f => f a -> f b -> f b
(*>) forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. Element mono -> f b
f) (forall (f :: * -> *) a. Applicative f => a -> f a
pure ())
{-# INLINE otraverse_ #-}
ofor_ :: Applicative f => mono -> (Element mono -> f b) -> f ()
ofor_ = forall a b c. (a -> b -> c) -> b -> a -> c
flip forall mono (f :: * -> *) b.
(MonoFoldable mono, Applicative f) =>
(Element mono -> f b) -> mono -> f ()
otraverse_
{-# INLINE ofor_ #-}
omapM_ :: Applicative m => (Element mono -> m ()) -> mono -> m ()
omapM_ = forall mono (f :: * -> *) b.
(MonoFoldable mono, Applicative f) =>
(Element mono -> f b) -> mono -> f ()
otraverse_
{-# INLINE omapM_ #-}
oforM_ :: Applicative m => mono -> (Element mono -> m ()) -> m ()
oforM_ = forall a b c. (a -> b -> c) -> b -> a -> c
flip forall mono (m :: * -> *).
(MonoFoldable mono, Applicative m) =>
(Element mono -> m ()) -> mono -> m ()
omapM_
{-# INLINE oforM_ #-}
ofoldlM :: Monad m => (a -> Element mono -> m a) -> a -> mono -> m a
ofoldlM a -> Element mono -> m a
f a
z0 mono
xs = forall mono b.
MonoFoldable mono =>
(Element mono -> b -> b) -> b -> mono -> b
ofoldr Element mono -> (a -> m a) -> a -> m a
f' forall (m :: * -> *) a. Monad m => a -> m a
return mono
xs a
z0
where f' :: Element mono -> (a -> m a) -> a -> m a
f' Element mono
x a -> m a
k a
z = a -> Element mono -> m a
f a
z Element mono
x forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= a -> m a
k
{-# INLINE ofoldlM #-}
ofoldMap1Ex :: Semigroup m => (Element mono -> m) -> mono -> m
ofoldMap1Ex Element mono -> m
f = forall a. a -> Maybe a -> a
fromMaybe (forall a. HasCallStack => [Char] -> a
Prelude.error [Char]
"Data.MonoTraversable.ofoldMap1Ex")
forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono m.
(MonoFoldable mono, Monoid m) =>
(Element mono -> m) -> mono -> m
ofoldMap (forall a. a -> Maybe a
Just forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. Element mono -> m
f)
ofoldr1Ex :: (Element mono -> Element mono -> Element mono) -> mono -> Element mono
default ofoldr1Ex :: (t a ~ mono, a ~ Element (t a), F.Foldable t)
=> (Element mono -> Element mono -> Element mono) -> mono -> Element mono
ofoldr1Ex = forall (t :: * -> *) a. Foldable t => (a -> a -> a) -> t a -> a
F.foldr1
{-# INLINE ofoldr1Ex #-}
ofoldl1Ex' :: (Element mono -> Element mono -> Element mono) -> mono -> Element mono
default ofoldl1Ex' :: (t a ~ mono, a ~ Element (t a), F.Foldable t)
=> (Element mono -> Element mono -> Element mono) -> mono -> Element mono
ofoldl1Ex' = forall (t :: * -> *) a. Foldable t => (a -> a -> a) -> t a -> a
F.foldl1
{-# INLINE ofoldl1Ex' #-}
headEx :: mono -> Element mono
headEx = forall mono b.
MonoFoldable mono =>
(Element mono -> b -> b) -> b -> mono -> b
ofoldr forall a b. a -> b -> a
const (forall a. HasCallStack => [Char] -> a
Prelude.error [Char]
"Data.MonoTraversable.headEx: empty")
{-# INLINE headEx #-}
lastEx :: mono -> Element mono
lastEx = forall mono.
MonoFoldable mono =>
(Element mono -> Element mono -> Element mono)
-> mono -> Element mono
ofoldl1Ex' (forall a b c. (a -> b -> c) -> b -> a -> c
flip forall a b. a -> b -> a
const)
{-# INLINE lastEx #-}
unsafeHead :: mono -> Element mono
unsafeHead = forall mono. MonoFoldable mono => mono -> Element mono
headEx
{-# INLINE unsafeHead #-}
unsafeLast :: mono -> Element mono
unsafeLast = forall mono. MonoFoldable mono => mono -> Element mono
lastEx
{-# INLINE unsafeLast #-}
maximumByEx :: (Element mono -> Element mono -> Ordering) -> mono -> Element mono
maximumByEx Element mono -> Element mono -> Ordering
f =
forall mono.
MonoFoldable mono =>
(Element mono -> Element mono -> Element mono)
-> mono -> Element mono
ofoldl1Ex' Element mono -> Element mono -> Element mono
go
where
go :: Element mono -> Element mono -> Element mono
go Element mono
x Element mono
y =
case Element mono -> Element mono -> Ordering
f Element mono
x Element mono
y of
Ordering
LT -> Element mono
y
Ordering
_ -> Element mono
x
{-# INLINE maximumByEx #-}
minimumByEx :: (Element mono -> Element mono -> Ordering) -> mono -> Element mono
minimumByEx Element mono -> Element mono -> Ordering
f =
forall mono.
MonoFoldable mono =>
(Element mono -> Element mono -> Element mono)
-> mono -> Element mono
ofoldl1Ex' Element mono -> Element mono -> Element mono
go
where
go :: Element mono -> Element mono -> Element mono
go Element mono
x Element mono
y =
case Element mono -> Element mono -> Ordering
f Element mono
x Element mono
y of
Ordering
GT -> Element mono
y
Ordering
_ -> Element mono
x
{-# INLINE minimumByEx #-}
oelem :: Eq (Element mono) => Element mono -> mono -> Bool
oelem Element mono
e = forall (t :: * -> *) a. (Foldable t, Eq a) => a -> t a -> Bool
List.elem Element mono
e forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono. MonoFoldable mono => mono -> [Element mono]
otoList
{-# INLINE [0] oelem #-}
onotElem :: Eq (Element mono) => Element mono -> mono -> Bool
onotElem Element mono
e = forall (t :: * -> *) a. (Foldable t, Eq a) => a -> t a -> Bool
List.notElem Element mono
e forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono. MonoFoldable mono => mono -> [Element mono]
otoList
{-# INLINE [0] onotElem #-}
instance MonoFoldable S.ByteString where
ofoldMap :: forall m. Monoid m => (Element ByteString -> m) -> ByteString -> m
ofoldMap Element ByteString -> m
f = forall mono b.
MonoFoldable mono =>
(Element mono -> b -> b) -> b -> mono -> b
ofoldr (forall a. Monoid a => a -> a -> a
mappend forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. Element ByteString -> m
f) forall a. Monoid a => a
mempty
ofoldr :: forall b. (Element ByteString -> b -> b) -> b -> ByteString -> b
ofoldr = forall a. (Word8 -> a -> a) -> a -> ByteString -> a
S.foldr
ofoldl' :: forall a. (a -> Element ByteString -> a) -> a -> ByteString -> a
ofoldl' = forall a. (a -> Word8 -> a) -> a -> ByteString -> a
S.foldl'
otoList :: ByteString -> [Element ByteString]
otoList = ByteString -> [Word8]
S.unpack
oall :: (Element ByteString -> Bool) -> ByteString -> Bool
oall = (Word8 -> Bool) -> ByteString -> Bool
S.all
oany :: (Element ByteString -> Bool) -> ByteString -> Bool
oany = (Word8 -> Bool) -> ByteString -> Bool
S.any
onull :: ByteString -> Bool
onull = ByteString -> Bool
S.null
olength :: ByteString -> Int
olength = ByteString -> Int
S.length
oelem :: Eq (Element ByteString) => Element ByteString -> ByteString -> Bool
oelem = Word8 -> ByteString -> Bool
S.elem
onotElem :: Eq (Element ByteString) => Element ByteString -> ByteString -> Bool
onotElem = Word8 -> ByteString -> Bool
S.notElem
omapM_ :: forall (m :: * -> *).
Applicative m =>
(Element ByteString -> m ()) -> ByteString -> m ()
omapM_ Element ByteString -> m ()
f (Unsafe.PS ForeignPtr Word8
fptr Int
offset Int
len) = do
let start :: Ptr Word8
start = forall a. ForeignPtr a -> Ptr a
Unsafe.unsafeForeignPtrToPtr ForeignPtr Word8
fptr forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
offset
end :: Ptr Word8
end = Ptr Word8
start forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
len
loop :: Ptr Word8 -> m ()
loop Ptr Word8
ptr
| Ptr Word8
ptr forall a. Ord a => a -> a -> Bool
>= Ptr Word8
end = forall {a}. IO a -> a
evil (forall a. ForeignPtr a -> IO ()
touchForeignPtr ForeignPtr Word8
fptr) seq :: forall a b. a -> b -> b
`seq`
forall (f :: * -> *) a. Applicative f => a -> f a
pure ()
| Bool
otherwise =
Element ByteString -> m ()
f (forall {a}. IO a -> a
evil (forall a. Storable a => Ptr a -> IO a
peek Ptr Word8
ptr)) forall (f :: * -> *) a b. Applicative f => f a -> f b -> f b
*>
Ptr Word8 -> m ()
loop (Ptr Word8
ptr forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
1)
Ptr Word8 -> m ()
loop Ptr Word8
start
where
#if MIN_VERSION_bytestring(0,10,6)
evil :: IO a -> a
evil = forall {a}. IO a -> a
Unsafe.accursedUnutterablePerformIO
#else
evil = Unsafe.inlinePerformIO
#endif
{-# INLINE evil #-}
ofoldr1Ex :: (Element ByteString -> Element ByteString -> Element ByteString)
-> ByteString -> Element ByteString
ofoldr1Ex = HasCallStack => (Word8 -> Word8 -> Word8) -> ByteString -> Word8
S.foldr1
ofoldl1Ex' :: (Element ByteString -> Element ByteString -> Element ByteString)
-> ByteString -> Element ByteString
ofoldl1Ex' = HasCallStack => (Word8 -> Word8 -> Word8) -> ByteString -> Word8
S.foldl1'
headEx :: ByteString -> Element ByteString
headEx = HasCallStack => ByteString -> Word8
S.head
lastEx :: ByteString -> Element ByteString
lastEx = HasCallStack => ByteString -> Word8
S.last
unsafeHead :: ByteString -> Element ByteString
unsafeHead = ByteString -> Word8
SU.unsafeHead
{-# INLINE ofoldMap #-}
{-# INLINE ofoldr #-}
{-# INLINE ofoldl' #-}
{-# INLINE otoList #-}
{-# INLINE oall #-}
{-# INLINE oany #-}
{-# INLINE onull #-}
{-# INLINE olength #-}
{-# INLINE omapM_ #-}
{-# INLINE ofoldr1Ex #-}
{-# INLINE ofoldl1Ex' #-}
{-# INLINE headEx #-}
{-# INLINE lastEx #-}
{-# INLINE unsafeHead #-}
{-# INLINE oelem #-}
{-# INLINE onotElem #-}
{-# RULES "strict ByteString: ofoldMap = concatMap" ofoldMap = S.concatMap #-}
instance MonoFoldable L.ByteString where
ofoldMap :: forall m. Monoid m => (Element ByteString -> m) -> ByteString -> m
ofoldMap Element ByteString -> m
f = forall mono b.
MonoFoldable mono =>
(Element mono -> b -> b) -> b -> mono -> b
ofoldr (forall a. Monoid a => a -> a -> a
mappend forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. Element ByteString -> m
f) forall a. Monoid a => a
mempty
ofoldr :: forall b. (Element ByteString -> b -> b) -> b -> ByteString -> b
ofoldr = forall a. (Word8 -> a -> a) -> a -> ByteString -> a
L.foldr
ofoldl' :: forall a. (a -> Element ByteString -> a) -> a -> ByteString -> a
ofoldl' = forall a. (a -> Word8 -> a) -> a -> ByteString -> a
L.foldl'
otoList :: ByteString -> [Element ByteString]
otoList = ByteString -> [Word8]
L.unpack
oall :: (Element ByteString -> Bool) -> ByteString -> Bool
oall = (Word8 -> Bool) -> ByteString -> Bool
L.all
oany :: (Element ByteString -> Bool) -> ByteString -> Bool
oany = (Word8 -> Bool) -> ByteString -> Bool
L.any
onull :: ByteString -> Bool
onull = ByteString -> Bool
L.null
olength64 :: ByteString -> Int64
olength64 = ByteString -> Int64
L.length
omapM_ :: forall (m :: * -> *).
Applicative m =>
(Element ByteString -> m ()) -> ByteString -> m ()
omapM_ Element ByteString -> m ()
f = forall mono (m :: * -> *).
(MonoFoldable mono, Applicative m) =>
(Element mono -> m ()) -> mono -> m ()
omapM_ (forall mono (m :: * -> *).
(MonoFoldable mono, Applicative m) =>
(Element mono -> m ()) -> mono -> m ()
omapM_ Element ByteString -> m ()
f) forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. ByteString -> [ByteString]
L.toChunks
ofoldr1Ex :: (Element ByteString -> Element ByteString -> Element ByteString)
-> ByteString -> Element ByteString
ofoldr1Ex = HasCallStack => (Word8 -> Word8 -> Word8) -> ByteString -> Word8
L.foldr1
ofoldl1Ex' :: (Element ByteString -> Element ByteString -> Element ByteString)
-> ByteString -> Element ByteString
ofoldl1Ex' = HasCallStack => (Word8 -> Word8 -> Word8) -> ByteString -> Word8
L.foldl1'
headEx :: ByteString -> Element ByteString
headEx = HasCallStack => ByteString -> Word8
L.head
lastEx :: ByteString -> Element ByteString
lastEx = HasCallStack => ByteString -> Word8
L.last
oelem :: Eq (Element ByteString) => Element ByteString -> ByteString -> Bool
oelem = Word8 -> ByteString -> Bool
L.elem
onotElem :: Eq (Element ByteString) => Element ByteString -> ByteString -> Bool
onotElem = Word8 -> ByteString -> Bool
L.notElem
{-# INLINE ofoldMap #-}
{-# INLINE ofoldr #-}
{-# INLINE ofoldl' #-}
{-# INLINE otoList #-}
{-# INLINE oall #-}
{-# INLINE oany #-}
{-# INLINE onull #-}
{-# INLINE olength64 #-}
{-# INLINE omapM_ #-}
{-# INLINE ofoldr1Ex #-}
{-# INLINE ofoldl1Ex' #-}
{-# INLINE headEx #-}
{-# INLINE lastEx #-}
{-# INLINE oelem #-}
{-# INLINE onotElem #-}
{-# RULES "lazy ByteString: ofoldMap = concatMap" ofoldMap = L.concatMap #-}
instance MonoFoldable T.Text where
ofoldMap :: forall m. Monoid m => (Element Text -> m) -> Text -> m
ofoldMap Element Text -> m
f = forall mono b.
MonoFoldable mono =>
(Element mono -> b -> b) -> b -> mono -> b
ofoldr (forall a. Monoid a => a -> a -> a
mappend forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. Element Text -> m
f) forall a. Monoid a => a
mempty
ofoldr :: forall b. (Element Text -> b -> b) -> b -> Text -> b
ofoldr = forall a. (Char -> a -> a) -> a -> Text -> a
T.foldr
ofoldl' :: forall a. (a -> Element Text -> a) -> a -> Text -> a
ofoldl' = forall a. (a -> Char -> a) -> a -> Text -> a
T.foldl'
otoList :: Text -> [Element Text]
otoList = Text -> [Char]
T.unpack
oall :: (Element Text -> Bool) -> Text -> Bool
oall = (Char -> Bool) -> Text -> Bool
T.all
oany :: (Element Text -> Bool) -> Text -> Bool
oany = (Char -> Bool) -> Text -> Bool
T.any
onull :: Text -> Bool
onull = Text -> Bool
T.null
olength :: Text -> Int
olength = Text -> Int
T.length
ofoldr1Ex :: (Element Text -> Element Text -> Element Text)
-> Text -> Element Text
ofoldr1Ex = (Char -> Char -> Char) -> Text -> Char
T.foldr1
ofoldl1Ex' :: (Element Text -> Element Text -> Element Text)
-> Text -> Element Text
ofoldl1Ex' = (Char -> Char -> Char) -> Text -> Char
T.foldl1'
headEx :: Text -> Element Text
headEx = Text -> Char
T.head
lastEx :: Text -> Element Text
lastEx = Text -> Char
T.last
{-# INLINE ofoldMap #-}
{-# INLINE ofoldr #-}
{-# INLINE ofoldl' #-}
{-# INLINE otoList #-}
{-# INLINE oall #-}
{-# INLINE oany #-}
{-# INLINE onull #-}
{-# INLINE olength #-}
{-# INLINE ofoldr1Ex #-}
{-# INLINE ofoldl1Ex' #-}
{-# INLINE headEx #-}
{-# INLINE lastEx #-}
{-# RULES "strict Text: ofoldMap = concatMap" ofoldMap = T.concatMap #-}
instance MonoFoldable TL.Text where
ofoldMap :: forall m. Monoid m => (Element Text -> m) -> Text -> m
ofoldMap Element Text -> m
f = forall mono b.
MonoFoldable mono =>
(Element mono -> b -> b) -> b -> mono -> b
ofoldr (forall a. Monoid a => a -> a -> a
mappend forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. Element Text -> m
f) forall a. Monoid a => a
mempty
ofoldr :: forall b. (Element Text -> b -> b) -> b -> Text -> b
ofoldr = forall a. (Char -> a -> a) -> a -> Text -> a
TL.foldr
ofoldl' :: forall a. (a -> Element Text -> a) -> a -> Text -> a
ofoldl' = forall a. (a -> Char -> a) -> a -> Text -> a
TL.foldl'
otoList :: Text -> [Element Text]
otoList = Text -> [Char]
TL.unpack
oall :: (Element Text -> Bool) -> Text -> Bool
oall = (Char -> Bool) -> Text -> Bool
TL.all
oany :: (Element Text -> Bool) -> Text -> Bool
oany = (Char -> Bool) -> Text -> Bool
TL.any
onull :: Text -> Bool
onull = Text -> Bool
TL.null
olength64 :: Text -> Int64
olength64 = Text -> Int64
TL.length
ofoldr1Ex :: (Element Text -> Element Text -> Element Text)
-> Text -> Element Text
ofoldr1Ex = (Char -> Char -> Char) -> Text -> Char
TL.foldr1
ofoldl1Ex' :: (Element Text -> Element Text -> Element Text)
-> Text -> Element Text
ofoldl1Ex' = (Char -> Char -> Char) -> Text -> Char
TL.foldl1'
headEx :: Text -> Element Text
headEx = Text -> Char
TL.head
lastEx :: Text -> Element Text
lastEx = Text -> Char
TL.last
{-# INLINE ofoldMap #-}
{-# INLINE ofoldr #-}
{-# INLINE ofoldl' #-}
{-# INLINE otoList #-}
{-# INLINE oall #-}
{-# INLINE oany #-}
{-# INLINE onull #-}
{-# INLINE ofoldr1Ex #-}
{-# INLINE ofoldl1Ex' #-}
{-# INLINE headEx #-}
{-# INLINE lastEx #-}
{-# RULES "lazy Text: ofoldMap = concatMap" ofoldMap = TL.concatMap #-}
instance MonoFoldable IntSet where
ofoldMap :: forall m. Monoid m => (Element IntSet -> m) -> IntSet -> m
ofoldMap Element IntSet -> m
f = forall mono b.
MonoFoldable mono =>
(Element mono -> b -> b) -> b -> mono -> b
ofoldr (forall a. Monoid a => a -> a -> a
mappend forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. Element IntSet -> m
f) forall a. Monoid a => a
mempty
ofoldr :: forall b. (Element IntSet -> b -> b) -> b -> IntSet -> b
ofoldr = forall b. (Int -> b -> b) -> b -> IntSet -> b
IntSet.foldr
ofoldl' :: forall a. (a -> Element IntSet -> a) -> a -> IntSet -> a
ofoldl' = forall a. (a -> Int -> a) -> a -> IntSet -> a
IntSet.foldl'
otoList :: IntSet -> [Element IntSet]
otoList = IntSet -> [Int]
IntSet.toList
onull :: IntSet -> Bool
onull = IntSet -> Bool
IntSet.null
olength :: IntSet -> Int
olength = IntSet -> Int
IntSet.size
ofoldr1Ex :: (Element IntSet -> Element IntSet -> Element IntSet)
-> IntSet -> Element IntSet
ofoldr1Ex Element IntSet -> Element IntSet -> Element IntSet
f = forall mono.
MonoFoldable mono =>
(Element mono -> Element mono -> Element mono)
-> mono -> Element mono
ofoldr1Ex Element IntSet -> Element IntSet -> Element IntSet
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. IntSet -> [Int]
IntSet.toList
ofoldl1Ex' :: (Element IntSet -> Element IntSet -> Element IntSet)
-> IntSet -> Element IntSet
ofoldl1Ex' Element IntSet -> Element IntSet -> Element IntSet
f = forall mono.
MonoFoldable mono =>
(Element mono -> Element mono -> Element mono)
-> mono -> Element mono
ofoldl1Ex' Element IntSet -> Element IntSet -> Element IntSet
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. IntSet -> [Int]
IntSet.toList
{-# INLINE ofoldMap #-}
{-# INLINE ofoldr #-}
{-# INLINE ofoldl' #-}
{-# INLINE otoList #-}
{-# INLINE onull #-}
{-# INLINE olength #-}
{-# INLINE ofoldr1Ex #-}
{-# INLINE ofoldl1Ex' #-}
instance MonoFoldable [a] where
otoList :: [a] -> [Element [a]]
otoList = forall {k} (cat :: k -> k -> *) (a :: k). Category cat => cat a a
id
{-# INLINE otoList #-}
ocompareLength :: forall i. Integral i => [a] -> i -> Ordering
ocompareLength [] i
i = i
0 forall a. Ord a => a -> a -> Ordering
`compare` i
i
ocompareLength (a
_:[a]
xs) i
i
| i
i forall a. Ord a => a -> a -> Bool
Prelude.<= i
0 = Ordering
GT
| Bool
otherwise = forall mono i.
(MonoFoldable mono, Integral i) =>
mono -> i -> Ordering
ocompareLength [a]
xs (i
i forall a. Num a => a -> a -> a
- i
1)
instance MonoFoldable (Maybe a) where
omapM_ :: forall (m :: * -> *).
Applicative m =>
(Element (Maybe a) -> m ()) -> Maybe a -> m ()
omapM_ Element (Maybe a) -> m ()
_ Maybe a
Nothing = forall (f :: * -> *) a. Applicative f => a -> f a
pure ()
omapM_ Element (Maybe a) -> m ()
f (Just a
x) = Element (Maybe a) -> m ()
f a
x
{-# INLINE omapM_ #-}
instance MonoFoldable (Tree a)
instance MonoFoldable (Seq a) where
headEx :: Seq a -> Element (Seq a)
headEx = forall a b c. (a -> b -> c) -> b -> a -> c
flip forall a. Seq a -> Int -> a
Seq.index Int
0
lastEx :: Seq a -> Element (Seq a)
lastEx Seq a
xs = forall a. Seq a -> Int -> a
Seq.index Seq a
xs (forall a. Seq a -> Int
Seq.length Seq a
xs forall a. Num a => a -> a -> a
- Int
1)
{-# INLINE headEx #-}
{-# INLINE lastEx #-}
instance MonoFoldable (ViewL a)
instance MonoFoldable (ViewR a)
instance MonoFoldable (IntMap a)
#if !MIN_VERSION_base(4,16,0)
instance MonoFoldable (Option a)
#endif
instance MonoFoldable (NonEmpty a)
instance MonoFoldable (Identity a)
instance MonoFoldable (Map k v) where
olength :: Map k v -> Int
olength = forall k v. Map k v -> Int
Map.size
{-# INLINE olength #-}
instance MonoFoldable (HashMap k v)
instance MonoFoldable (Vector a) where
ofoldr :: forall b. (Element (Vector a) -> b -> b) -> b -> Vector a -> b
ofoldr = forall a b. (a -> b -> b) -> b -> Vector a -> b
V.foldr
ofoldl' :: forall a. (a -> Element (Vector a) -> a) -> a -> Vector a -> a
ofoldl' = forall a b. (a -> b -> a) -> a -> Vector b -> a
V.foldl'
otoList :: Vector a -> [Element (Vector a)]
otoList = forall a. Vector a -> [a]
V.toList
oall :: (Element (Vector a) -> Bool) -> Vector a -> Bool
oall = forall a. (a -> Bool) -> Vector a -> Bool
V.all
oany :: (Element (Vector a) -> Bool) -> Vector a -> Bool
oany = forall a. (a -> Bool) -> Vector a -> Bool
V.any
onull :: Vector a -> Bool
onull = forall a. Vector a -> Bool
V.null
olength :: Vector a -> Int
olength = forall a. Vector a -> Int
V.length
ofoldr1Ex :: (Element (Vector a) -> Element (Vector a) -> Element (Vector a))
-> Vector a -> Element (Vector a)
ofoldr1Ex = forall a. (a -> a -> a) -> Vector a -> a
V.foldr1
ofoldl1Ex' :: (Element (Vector a) -> Element (Vector a) -> Element (Vector a))
-> Vector a -> Element (Vector a)
ofoldl1Ex' = forall a. (a -> a -> a) -> Vector a -> a
V.foldl1'
headEx :: Vector a -> Element (Vector a)
headEx = forall a. Vector a -> a
V.head
lastEx :: Vector a -> Element (Vector a)
lastEx = forall a. Vector a -> a
V.last
unsafeHead :: Vector a -> Element (Vector a)
unsafeHead = forall a. Vector a -> a
V.unsafeHead
unsafeLast :: Vector a -> Element (Vector a)
unsafeLast = forall a. Vector a -> a
V.unsafeLast
maximumByEx :: (Element (Vector a) -> Element (Vector a) -> Ordering)
-> Vector a -> Element (Vector a)
maximumByEx = forall a. (a -> a -> Ordering) -> Vector a -> a
V.maximumBy
minimumByEx :: (Element (Vector a) -> Element (Vector a) -> Ordering)
-> Vector a -> Element (Vector a)
minimumByEx = forall a. (a -> a -> Ordering) -> Vector a -> a
V.minimumBy
{-# INLINE ofoldr #-}
{-# INLINE ofoldl' #-}
{-# INLINE otoList #-}
{-# INLINE oall #-}
{-# INLINE oany #-}
{-# INLINE onull #-}
{-# INLINE olength #-}
{-# INLINE ofoldr1Ex #-}
{-# INLINE ofoldl1Ex' #-}
{-# INLINE headEx #-}
{-# INLINE lastEx #-}
{-# INLINE unsafeHead #-}
{-# INLINE maximumByEx #-}
{-# INLINE minimumByEx #-}
instance Ord e => MonoFoldable (Set e) where
olength :: Set e -> Int
olength = forall a. Set a -> Int
Set.size
oelem :: Eq (Element (Set e)) => Element (Set e) -> Set e -> Bool
oelem = forall a. Ord a => a -> Set a -> Bool
Set.member
onotElem :: Eq (Element (Set e)) => Element (Set e) -> Set e -> Bool
onotElem = forall a. Ord a => a -> Set a -> Bool
Set.notMember
{-# INLINE olength #-}
{-# INLINE oelem #-}
{-# INLINE onotElem #-}
instance MonoFoldable (HashSet e)
instance U.Unbox a => MonoFoldable (U.Vector a) where
ofoldMap :: forall m. Monoid m => (Element (Vector a) -> m) -> Vector a -> m
ofoldMap Element (Vector a) -> m
f = forall mono b.
MonoFoldable mono =>
(Element mono -> b -> b) -> b -> mono -> b
ofoldr (forall a. Monoid a => a -> a -> a
mappend forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. Element (Vector a) -> m
f) forall a. Monoid a => a
mempty
ofoldr :: forall b. (Element (Vector a) -> b -> b) -> b -> Vector a -> b
ofoldr = forall a b. Unbox a => (a -> b -> b) -> b -> Vector a -> b
U.foldr
ofoldl' :: forall a. (a -> Element (Vector a) -> a) -> a -> Vector a -> a
ofoldl' = forall b a. Unbox b => (a -> b -> a) -> a -> Vector b -> a
U.foldl'
otoList :: Vector a -> [Element (Vector a)]
otoList = forall a. Unbox a => Vector a -> [a]
U.toList
oall :: (Element (Vector a) -> Bool) -> Vector a -> Bool
oall = forall a. Unbox a => (a -> Bool) -> Vector a -> Bool
U.all
oany :: (Element (Vector a) -> Bool) -> Vector a -> Bool
oany = forall a. Unbox a => (a -> Bool) -> Vector a -> Bool
U.any
onull :: Vector a -> Bool
onull = forall a. Unbox a => Vector a -> Bool
U.null
olength :: Vector a -> Int
olength = forall a. Unbox a => Vector a -> Int
U.length
ofoldr1Ex :: (Element (Vector a) -> Element (Vector a) -> Element (Vector a))
-> Vector a -> Element (Vector a)
ofoldr1Ex = forall a. Unbox a => (a -> a -> a) -> Vector a -> a
U.foldr1
ofoldl1Ex' :: (Element (Vector a) -> Element (Vector a) -> Element (Vector a))
-> Vector a -> Element (Vector a)
ofoldl1Ex' = forall a. Unbox a => (a -> a -> a) -> Vector a -> a
U.foldl1'
headEx :: Vector a -> Element (Vector a)
headEx = forall a. Unbox a => Vector a -> a
U.head
lastEx :: Vector a -> Element (Vector a)
lastEx = forall a. Unbox a => Vector a -> a
U.last
unsafeHead :: Vector a -> Element (Vector a)
unsafeHead = forall a. Unbox a => Vector a -> a
U.unsafeHead
unsafeLast :: Vector a -> Element (Vector a)
unsafeLast = forall a. Unbox a => Vector a -> a
U.unsafeLast
maximumByEx :: (Element (Vector a) -> Element (Vector a) -> Ordering)
-> Vector a -> Element (Vector a)
maximumByEx = forall a. Unbox a => (a -> a -> Ordering) -> Vector a -> a
U.maximumBy
minimumByEx :: (Element (Vector a) -> Element (Vector a) -> Ordering)
-> Vector a -> Element (Vector a)
minimumByEx = forall a. Unbox a => (a -> a -> Ordering) -> Vector a -> a
U.minimumBy
{-# INLINE ofoldMap #-}
{-# INLINE ofoldr #-}
{-# INLINE ofoldl' #-}
{-# INLINE otoList #-}
{-# INLINE oall #-}
{-# INLINE oany #-}
{-# INLINE onull #-}
{-# INLINE olength #-}
{-# INLINE ofoldr1Ex #-}
{-# INLINE ofoldl1Ex' #-}
{-# INLINE headEx #-}
{-# INLINE lastEx #-}
{-# INLINE unsafeHead #-}
{-# INLINE maximumByEx #-}
{-# INLINE minimumByEx #-}
instance VS.Storable a => MonoFoldable (VS.Vector a) where
ofoldMap :: forall m. Monoid m => (Element (Vector a) -> m) -> Vector a -> m
ofoldMap Element (Vector a) -> m
f = forall mono b.
MonoFoldable mono =>
(Element mono -> b -> b) -> b -> mono -> b
ofoldr (forall a. Monoid a => a -> a -> a
mappend forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. Element (Vector a) -> m
f) forall a. Monoid a => a
mempty
ofoldr :: forall b. (Element (Vector a) -> b -> b) -> b -> Vector a -> b
ofoldr = forall a b. Storable a => (a -> b -> b) -> b -> Vector a -> b
VS.foldr
ofoldl' :: forall a. (a -> Element (Vector a) -> a) -> a -> Vector a -> a
ofoldl' = forall b a. Storable b => (a -> b -> a) -> a -> Vector b -> a
VS.foldl'
otoList :: Vector a -> [Element (Vector a)]
otoList = forall a. Storable a => Vector a -> [a]
VS.toList
oall :: (Element (Vector a) -> Bool) -> Vector a -> Bool
oall = forall a. Storable a => (a -> Bool) -> Vector a -> Bool
VS.all
oany :: (Element (Vector a) -> Bool) -> Vector a -> Bool
oany = forall a. Storable a => (a -> Bool) -> Vector a -> Bool
VS.any
onull :: Vector a -> Bool
onull = forall a. Storable a => Vector a -> Bool
VS.null
olength :: Vector a -> Int
olength = forall a. Storable a => Vector a -> Int
VS.length
ofoldr1Ex :: (Element (Vector a) -> Element (Vector a) -> Element (Vector a))
-> Vector a -> Element (Vector a)
ofoldr1Ex = forall a. Storable a => (a -> a -> a) -> Vector a -> a
VS.foldr1
ofoldl1Ex' :: (Element (Vector a) -> Element (Vector a) -> Element (Vector a))
-> Vector a -> Element (Vector a)
ofoldl1Ex' = forall a. Storable a => (a -> a -> a) -> Vector a -> a
VS.foldl1'
headEx :: Vector a -> Element (Vector a)
headEx = forall a. Storable a => Vector a -> a
VS.head
lastEx :: Vector a -> Element (Vector a)
lastEx = forall a. Storable a => Vector a -> a
VS.last
unsafeHead :: Vector a -> Element (Vector a)
unsafeHead = forall a. Storable a => Vector a -> a
VS.unsafeHead
unsafeLast :: Vector a -> Element (Vector a)
unsafeLast = forall a. Storable a => Vector a -> a
VS.unsafeLast
maximumByEx :: (Element (Vector a) -> Element (Vector a) -> Ordering)
-> Vector a -> Element (Vector a)
maximumByEx = forall a. Storable a => (a -> a -> Ordering) -> Vector a -> a
VS.maximumBy
minimumByEx :: (Element (Vector a) -> Element (Vector a) -> Ordering)
-> Vector a -> Element (Vector a)
minimumByEx = forall a. Storable a => (a -> a -> Ordering) -> Vector a -> a
VS.minimumBy
{-# INLINE ofoldMap #-}
{-# INLINE ofoldr #-}
{-# INLINE ofoldl' #-}
{-# INLINE otoList #-}
{-# INLINE oall #-}
{-# INLINE oany #-}
{-# INLINE onull #-}
{-# INLINE olength #-}
{-# INLINE ofoldr1Ex #-}
{-# INLINE ofoldl1Ex' #-}
{-# INLINE headEx #-}
{-# INLINE lastEx #-}
{-# INLINE unsafeHead #-}
{-# INLINE maximumByEx #-}
{-# INLINE minimumByEx #-}
instance MonoFoldable (Either a b) where
ofoldMap :: forall m.
Monoid m =>
(Element (Either a b) -> m) -> Either a b -> m
ofoldMap Element (Either a b) -> m
f = forall mono b.
MonoFoldable mono =>
(Element mono -> b -> b) -> b -> mono -> b
ofoldr (forall a. Monoid a => a -> a -> a
mappend forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. Element (Either a b) -> m
f) forall a. Monoid a => a
mempty
ofoldr :: forall b. (Element (Either a b) -> b -> b) -> b -> Either a b -> b
ofoldr Element (Either a b) -> b -> b
f b
b (Right b
a) = Element (Either a b) -> b -> b
f b
a b
b
ofoldr Element (Either a b) -> b -> b
_ b
b (Left a
_) = b
b
ofoldl' :: forall a. (a -> Element (Either a b) -> a) -> a -> Either a b -> a
ofoldl' a -> Element (Either a b) -> a
f a
a (Right b
b) = a -> Element (Either a b) -> a
f a
a b
b
ofoldl' a -> Element (Either a b) -> a
_ a
a (Left a
_) = a
a
otoList :: Either a b -> [Element (Either a b)]
otoList (Left a
_) = []
otoList (Right b
b) = [b
b]
oall :: (Element (Either a b) -> Bool) -> Either a b -> Bool
oall Element (Either a b) -> Bool
_ (Left a
_) = Bool
True
oall Element (Either a b) -> Bool
f (Right b
b) = Element (Either a b) -> Bool
f b
b
oany :: (Element (Either a b) -> Bool) -> Either a b -> Bool
oany Element (Either a b) -> Bool
_ (Left a
_) = Bool
False
oany Element (Either a b) -> Bool
f (Right b
b) = Element (Either a b) -> Bool
f b
b
onull :: Either a b -> Bool
onull (Left a
_) = Bool
True
onull (Right b
_) = Bool
False
olength :: Either a b -> Int
olength (Left a
_) = Int
0
olength (Right b
_) = Int
1
ofoldr1Ex :: (Element (Either a b)
-> Element (Either a b) -> Element (Either a b))
-> Either a b -> Element (Either a b)
ofoldr1Ex Element (Either a b)
-> Element (Either a b) -> Element (Either a b)
_ (Left a
_) = forall a. HasCallStack => [Char] -> a
Prelude.error [Char]
"ofoldr1Ex on Either"
ofoldr1Ex Element (Either a b)
-> Element (Either a b) -> Element (Either a b)
_ (Right b
x) = b
x
ofoldl1Ex' :: (Element (Either a b)
-> Element (Either a b) -> Element (Either a b))
-> Either a b -> Element (Either a b)
ofoldl1Ex' Element (Either a b)
-> Element (Either a b) -> Element (Either a b)
_ (Left a
_) = forall a. HasCallStack => [Char] -> a
Prelude.error [Char]
"ofoldl1Ex' on Either"
ofoldl1Ex' Element (Either a b)
-> Element (Either a b) -> Element (Either a b)
_ (Right b
x) = b
x
omapM_ :: forall (m :: * -> *).
Applicative m =>
(Element (Either a b) -> m ()) -> Either a b -> m ()
omapM_ Element (Either a b) -> m ()
_ (Left a
_) = forall (f :: * -> *) a. Applicative f => a -> f a
pure ()
omapM_ Element (Either a b) -> m ()
f (Right b
x) = Element (Either a b) -> m ()
f b
x
{-# INLINE ofoldMap #-}
{-# INLINE ofoldr #-}
{-# INLINE ofoldl' #-}
{-# INLINE otoList #-}
{-# INLINE oall #-}
{-# INLINE oany #-}
{-# INLINE onull #-}
{-# INLINE olength #-}
{-# INLINE omapM_ #-}
{-# INLINE ofoldr1Ex #-}
{-# INLINE ofoldl1Ex' #-}
instance MonoFoldable (a, b)
instance MonoFoldable (Const m a)
instance F.Foldable f => MonoFoldable (MaybeT f a)
#if !MIN_VERSION_transformers(0,6,0)
instance F.Foldable f => MonoFoldable (ListT f a)
#endif
instance F.Foldable f => MonoFoldable (IdentityT f a)
instance F.Foldable f => MonoFoldable (WriterT w f a)
instance F.Foldable f => MonoFoldable (Strict.WriterT w f a)
instance (F.Foldable f, F.Foldable g) => MonoFoldable (Compose f g a)
instance (F.Foldable f, F.Foldable g) => MonoFoldable (Product f g a)
instance (F.Foldable f, F.Foldable g) => MonoFoldable ((f :.: g) a)
instance (F.Foldable f, F.Foldable g) => MonoFoldable ((f :*: g) a)
instance (F.Foldable f, F.Foldable g) => MonoFoldable ((f :+: g) a)
instance MonoFoldable (K1 i c a)
instance F.Foldable f => MonoFoldable (M1 i c f a)
instance F.Foldable f => MonoFoldable (Rec1 f a)
instance MonoFoldable (Par1 a)
instance MonoFoldable (U1 a)
instance MonoFoldable (V1 a)
instance MonoFoldable (Proxy a)
headMay :: MonoFoldable mono => mono -> Maybe (Element mono)
headMay :: forall mono. MonoFoldable mono => mono -> Maybe (Element mono)
headMay mono
mono
| forall mono. MonoFoldable mono => mono -> Bool
onull mono
mono = forall a. Maybe a
Nothing
| Bool
otherwise = forall a. a -> Maybe a
Just (forall mono. MonoFoldable mono => mono -> Element mono
headEx mono
mono)
{-# INLINE headMay #-}
lastMay :: MonoFoldable mono => mono -> Maybe (Element mono)
lastMay :: forall mono. MonoFoldable mono => mono -> Maybe (Element mono)
lastMay mono
mono
| forall mono. MonoFoldable mono => mono -> Bool
onull mono
mono = forall a. Maybe a
Nothing
| Bool
otherwise = forall a. a -> Maybe a
Just (forall mono. MonoFoldable mono => mono -> Element mono
lastEx mono
mono)
{-# INLINE lastMay #-}
osum :: (MonoFoldable mono, Num (Element mono)) => mono -> Element mono
osum :: forall mono.
(MonoFoldable mono, Num (Element mono)) =>
mono -> Element mono
osum = forall mono a.
MonoFoldable mono =>
(a -> Element mono -> a) -> a -> mono -> a
ofoldl' forall a. Num a => a -> a -> a
(+) Element mono
0
{-# INLINE osum #-}
oproduct :: (MonoFoldable mono, Num (Element mono)) => mono -> Element mono
oproduct :: forall mono.
(MonoFoldable mono, Num (Element mono)) =>
mono -> Element mono
oproduct = forall mono a.
MonoFoldable mono =>
(a -> Element mono -> a) -> a -> mono -> a
ofoldl' forall a. Num a => a -> a -> a
(*) Element mono
1
{-# INLINE oproduct #-}
oand :: (Element mono ~ Bool, MonoFoldable mono) => mono -> Bool
oand :: forall mono.
(Element mono ~ Bool, MonoFoldable mono) =>
mono -> Bool
oand = forall mono.
MonoFoldable mono =>
(Element mono -> Bool) -> mono -> Bool
oall forall {k} (cat :: k -> k -> *) (a :: k). Category cat => cat a a
id
{-# INLINE oand #-}
oor :: (Element mono ~ Bool, MonoFoldable mono) => mono -> Bool
oor :: forall mono.
(Element mono ~ Bool, MonoFoldable mono) =>
mono -> Bool
oor = forall mono.
MonoFoldable mono =>
(Element mono -> Bool) -> mono -> Bool
oany forall {k} (cat :: k -> k -> *) (a :: k). Category cat => cat a a
id
{-# INLINE oor #-}
oconcatMap :: (MonoFoldable mono, Monoid m) => (Element mono -> m) -> mono -> m
oconcatMap :: forall mono m.
(MonoFoldable mono, Monoid m) =>
(Element mono -> m) -> mono -> m
oconcatMap = forall mono m.
(MonoFoldable mono, Monoid m) =>
(Element mono -> m) -> mono -> m
ofoldMap
ofold :: (MonoFoldable mono, Monoid (Element mono)) => mono -> Element mono
ofold :: forall mono.
(MonoFoldable mono, Monoid (Element mono)) =>
mono -> Element mono
ofold = forall mono m.
(MonoFoldable mono, Monoid m) =>
(Element mono -> m) -> mono -> m
ofoldMap forall {k} (cat :: k -> k -> *) (a :: k). Category cat => cat a a
id
{-# INLINE ofold #-}
oconcat :: (MonoFoldable mono, Monoid (Element mono)) => mono -> Element mono
oconcat :: forall mono.
(MonoFoldable mono, Monoid (Element mono)) =>
mono -> Element mono
oconcat = forall mono.
(MonoFoldable mono, Monoid (Element mono)) =>
mono -> Element mono
ofold
{-# INLINE oconcat #-}
ofoldM :: (MonoFoldable mono, Monad m) => (a -> Element mono -> m a) -> a -> mono -> m a
ofoldM :: forall mono (m :: * -> *) a.
(MonoFoldable mono, Monad m) =>
(a -> Element mono -> m a) -> a -> mono -> m a
ofoldM = forall mono (m :: * -> *) a.
(MonoFoldable mono, Monad m) =>
(a -> Element mono -> m a) -> a -> mono -> m a
ofoldlM
{-# INLINE ofoldM #-}
osequence_ :: (Applicative m, MonoFoldable mono, Element mono ~ (m ())) => mono -> m ()
osequence_ :: forall (m :: * -> *) mono.
(Applicative m, MonoFoldable mono, Element mono ~ m ()) =>
mono -> m ()
osequence_ = forall mono (m :: * -> *).
(MonoFoldable mono, Applicative m) =>
(Element mono -> m ()) -> mono -> m ()
omapM_ forall {k} (cat :: k -> k -> *) (a :: k). Category cat => cat a a
id
{-# INLINE osequence_ #-}
maximumEx :: (MonoFoldable mono, Ord (Element mono)) => mono -> Element mono
maximumEx :: forall mono.
(MonoFoldable mono, Ord (Element mono)) =>
mono -> Element mono
maximumEx = forall mono.
MonoFoldable mono =>
(Element mono -> Element mono -> Ordering) -> mono -> Element mono
maximumByEx forall a. Ord a => a -> a -> Ordering
compare
{-# INLINE [0] maximumEx #-}
minimumEx :: (MonoFoldable mono, Ord (Element mono)) => mono -> Element mono
minimumEx :: forall mono.
(MonoFoldable mono, Ord (Element mono)) =>
mono -> Element mono
minimumEx = forall mono.
MonoFoldable mono =>
(Element mono -> Element mono -> Ordering) -> mono -> Element mono
minimumByEx forall a. Ord a => a -> a -> Ordering
compare
{-# INLINE [0] minimumEx #-}
{-# RULES "strict ByteString maximumEx" maximumEx = S.maximum #-}
{-# RULES "strict ByteString minimumEx" minimumEx = S.minimum #-}
{-# RULES "lazy ByteString maximumEx" maximumEx = L.maximum #-}
{-# RULES "lazy ByteString minimumEx" minimumEx = L.minimum #-}
{-# RULES "strict Text maximumEx" maximumEx = T.maximum #-}
{-# RULES "strict Text minimumEx" minimumEx = T.minimum #-}
{-# RULES "lazy Text maximumEx" maximumEx = TL.maximum #-}
{-# RULES "lazy Text minimumEx" minimumEx = TL.minimum #-}
{-# RULES "boxed Vector maximumEx" maximumEx = V.maximum #-}
{-# RULES "boxed Vector minimumEx" minimumEx = V.minimum #-}
{-# RULES "unboxed Vector maximumEx" forall (u :: U.Unbox a => U.Vector a). maximumEx u = U.maximum u #-}
{-# RULES "unboxed Vector minimumEx" forall (u :: U.Unbox a => U.Vector a). minimumEx u = U.minimum u #-}
{-# RULES "storable Vector maximumEx" forall (v :: VS.Storable a => VS.Vector a). maximumEx v = VS.maximum v #-}
{-# RULES "storable Vector minimumEx" forall (v :: VS.Storable a => VS.Vector a). minimumEx v = VS.minimum v #-}
maximumMay :: (MonoFoldable mono, Ord (Element mono)) => mono -> Maybe (Element mono)
maximumMay :: forall mono.
(MonoFoldable mono, Ord (Element mono)) =>
mono -> Maybe (Element mono)
maximumMay mono
mono
| forall mono. MonoFoldable mono => mono -> Bool
onull mono
mono = forall a. Maybe a
Nothing
| Bool
otherwise = forall a. a -> Maybe a
Just (forall mono.
(MonoFoldable mono, Ord (Element mono)) =>
mono -> Element mono
maximumEx mono
mono)
{-# INLINE maximumMay #-}
maximumByMay :: MonoFoldable mono
=> (Element mono -> Element mono -> Ordering)
-> mono
-> Maybe (Element mono)
maximumByMay :: forall mono.
MonoFoldable mono =>
(Element mono -> Element mono -> Ordering)
-> mono -> Maybe (Element mono)
maximumByMay Element mono -> Element mono -> Ordering
f mono
mono
| forall mono. MonoFoldable mono => mono -> Bool
onull mono
mono = forall a. Maybe a
Nothing
| Bool
otherwise = forall a. a -> Maybe a
Just (forall mono.
MonoFoldable mono =>
(Element mono -> Element mono -> Ordering) -> mono -> Element mono
maximumByEx Element mono -> Element mono -> Ordering
f mono
mono)
{-# INLINE maximumByMay #-}
minimumMay :: (MonoFoldable mono, Ord (Element mono)) => mono -> Maybe (Element mono)
minimumMay :: forall mono.
(MonoFoldable mono, Ord (Element mono)) =>
mono -> Maybe (Element mono)
minimumMay mono
mono
| forall mono. MonoFoldable mono => mono -> Bool
onull mono
mono = forall a. Maybe a
Nothing
| Bool
otherwise = forall a. a -> Maybe a
Just (forall mono.
(MonoFoldable mono, Ord (Element mono)) =>
mono -> Element mono
minimumEx mono
mono)
{-# INLINE minimumMay #-}
minimumByMay :: MonoFoldable mono
=> (Element mono -> Element mono -> Ordering)
-> mono
-> Maybe (Element mono)
minimumByMay :: forall mono.
MonoFoldable mono =>
(Element mono -> Element mono -> Ordering)
-> mono -> Maybe (Element mono)
minimumByMay Element mono -> Element mono -> Ordering
f mono
mono
| forall mono. MonoFoldable mono => mono -> Bool
onull mono
mono = forall a. Maybe a
Nothing
| Bool
otherwise = forall a. a -> Maybe a
Just (forall mono.
MonoFoldable mono =>
(Element mono -> Element mono -> Ordering) -> mono -> Element mono
minimumByEx Element mono -> Element mono -> Ordering
f mono
mono)
{-# INLINE minimumByMay #-}
class (MonoFunctor mono, MonoFoldable mono) => MonoTraversable mono where
otraverse :: Applicative f => (Element mono -> f (Element mono)) -> mono -> f mono
default otraverse :: (Traversable t, mono ~ t a, a ~ Element mono, Applicative f) => (Element mono -> f (Element mono)) -> mono -> f mono
otraverse = forall (t :: * -> *) (f :: * -> *) a b.
(Traversable t, Applicative f) =>
(a -> f b) -> t a -> f (t b)
traverse
omapM :: Applicative m => (Element mono -> m (Element mono)) -> mono -> m mono
omapM = forall mono (m :: * -> *).
(MonoTraversable mono, Applicative m) =>
(Element mono -> m (Element mono)) -> mono -> m mono
otraverse
{-# INLINE otraverse #-}
{-# INLINE omapM #-}
instance MonoTraversable S.ByteString where
otraverse :: forall (m :: * -> *).
Applicative m =>
(Element ByteString -> m (Element ByteString))
-> ByteString -> m ByteString
otraverse Element ByteString -> f (Element ByteString)
f = forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap [Word8] -> ByteString
S.pack forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall (t :: * -> *) (f :: * -> *) a b.
(Traversable t, Applicative f) =>
(a -> f b) -> t a -> f (t b)
traverse Element ByteString -> f (Element ByteString)
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. ByteString -> [Word8]
S.unpack
{-# INLINE otraverse #-}
instance MonoTraversable L.ByteString where
otraverse :: forall (m :: * -> *).
Applicative m =>
(Element ByteString -> m (Element ByteString))
-> ByteString -> m ByteString
otraverse Element ByteString -> f (Element ByteString)
f = forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap [Word8] -> ByteString
L.pack forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall (t :: * -> *) (f :: * -> *) a b.
(Traversable t, Applicative f) =>
(a -> f b) -> t a -> f (t b)
traverse Element ByteString -> f (Element ByteString)
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. ByteString -> [Word8]
L.unpack
{-# INLINE otraverse #-}
instance MonoTraversable T.Text where
otraverse :: forall (m :: * -> *).
Applicative m =>
(Element Text -> m (Element Text)) -> Text -> m Text
otraverse Element Text -> f (Element Text)
f = forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap [Char] -> Text
T.pack forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall (t :: * -> *) (f :: * -> *) a b.
(Traversable t, Applicative f) =>
(a -> f b) -> t a -> f (t b)
traverse Element Text -> f (Element Text)
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. Text -> [Char]
T.unpack
{-# INLINE otraverse #-}
instance MonoTraversable TL.Text where
otraverse :: forall (m :: * -> *).
Applicative m =>
(Element Text -> m (Element Text)) -> Text -> m Text
otraverse Element Text -> f (Element Text)
f = forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap [Char] -> Text
TL.pack forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall (t :: * -> *) (f :: * -> *) a b.
(Traversable t, Applicative f) =>
(a -> f b) -> t a -> f (t b)
traverse Element Text -> f (Element Text)
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. Text -> [Char]
TL.unpack
{-# INLINE otraverse #-}
instance MonoTraversable [a]
instance MonoTraversable (Maybe a)
instance MonoTraversable (Tree a)
instance MonoTraversable (Seq a)
instance MonoTraversable (ViewL a)
instance MonoTraversable (ViewR a)
instance MonoTraversable (IntMap a)
#if !MIN_VERSION_base(4,16,0)
instance MonoTraversable (Option a)
#endif
instance MonoTraversable (NonEmpty a)
instance MonoTraversable (Identity a)
instance MonoTraversable (Map k v)
instance MonoTraversable (HashMap k v)
instance MonoTraversable (Vector a)
instance U.Unbox a => MonoTraversable (U.Vector a) where
otraverse :: forall (m :: * -> *).
Applicative m =>
(Element (Vector a) -> m (Element (Vector a)))
-> Vector a -> m (Vector a)
otraverse Element (Vector a) -> f (Element (Vector a))
f = forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap forall a. Unbox a => [a] -> Vector a
U.fromList forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall (t :: * -> *) (f :: * -> *) a b.
(Traversable t, Applicative f) =>
(a -> f b) -> t a -> f (t b)
traverse Element (Vector a) -> f (Element (Vector a))
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall a. Unbox a => Vector a -> [a]
U.toList
omapM :: forall (m :: * -> *).
Applicative m =>
(Element (Vector a) -> m (Element (Vector a)))
-> Vector a -> m (Vector a)
omapM = forall mono (m :: * -> *).
(MonoTraversable mono, Applicative m) =>
(Element mono -> m (Element mono)) -> mono -> m mono
otraverse
{-# INLINE otraverse #-}
{-# INLINE omapM #-}
instance VS.Storable a => MonoTraversable (VS.Vector a) where
otraverse :: forall (m :: * -> *).
Applicative m =>
(Element (Vector a) -> m (Element (Vector a)))
-> Vector a -> m (Vector a)
otraverse Element (Vector a) -> f (Element (Vector a))
f = forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap forall a. Storable a => [a] -> Vector a
VS.fromList forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall (t :: * -> *) (f :: * -> *) a b.
(Traversable t, Applicative f) =>
(a -> f b) -> t a -> f (t b)
traverse Element (Vector a) -> f (Element (Vector a))
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall a. Storable a => Vector a -> [a]
VS.toList
omapM :: forall (m :: * -> *).
Applicative m =>
(Element (Vector a) -> m (Element (Vector a)))
-> Vector a -> m (Vector a)
omapM = forall mono (m :: * -> *).
(MonoTraversable mono, Applicative m) =>
(Element mono -> m (Element mono)) -> mono -> m mono
otraverse
{-# INLINE otraverse #-}
{-# INLINE omapM #-}
instance MonoTraversable (Either a b) where
otraverse :: forall (m :: * -> *).
Applicative m =>
(Element (Either a b) -> m (Element (Either a b)))
-> Either a b -> m (Either a b)
otraverse Element (Either a b) -> f (Element (Either a b))
_ (Left a
a) = forall (f :: * -> *) a. Applicative f => a -> f a
pure (forall a b. a -> Either a b
Left a
a)
otraverse Element (Either a b) -> f (Element (Either a b))
f (Right b
b) = forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap forall a b. b -> Either a b
Right (Element (Either a b) -> f (Element (Either a b))
f b
b)
omapM :: forall (m :: * -> *).
Applicative m =>
(Element (Either a b) -> m (Element (Either a b)))
-> Either a b -> m (Either a b)
omapM Element (Either a b) -> m (Element (Either a b))
_ (Left a
a) = forall (f :: * -> *) a. Applicative f => a -> f a
pure (forall a b. a -> Either a b
Left a
a)
omapM Element (Either a b) -> m (Element (Either a b))
f (Right b
b) = forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap forall a b. b -> Either a b
Right (Element (Either a b) -> m (Element (Either a b))
f b
b)
{-# INLINE otraverse #-}
{-# INLINE omapM #-}
instance MonoTraversable (a, b)
instance MonoTraversable (Const m a)
instance Traversable f => MonoTraversable (MaybeT f a)
#if !MIN_VERSION_transformers(0,6,0)
instance Traversable f => MonoTraversable (ListT f a)
#endif
instance Traversable f => MonoTraversable (IdentityT f a)
instance Traversable f => MonoTraversable (WriterT w f a)
instance Traversable f => MonoTraversable (Strict.WriterT w f a)
instance (Traversable f, Traversable g) => MonoTraversable (Compose f g a)
instance (Traversable f, Traversable g) => MonoTraversable (Product f g a)
instance (Traversable f, Traversable g) => MonoTraversable ((f :.: g) a)
instance (Traversable f, Traversable g) => MonoTraversable ((f :*: g) a)
instance (Traversable f, Traversable g) => MonoTraversable ((f :+: g) a)
instance MonoTraversable (K1 i c a)
instance Traversable f => MonoTraversable (M1 i c f a)
instance Traversable f => MonoTraversable (Rec1 f a)
instance MonoTraversable (Par1 a)
instance MonoTraversable (U1 a)
instance MonoTraversable (V1 a)
instance MonoTraversable (Proxy a)
ofor :: (MonoTraversable mono, Applicative f) => mono -> (Element mono -> f (Element mono)) -> f mono
ofor :: forall mono (f :: * -> *).
(MonoTraversable mono, Applicative f) =>
mono -> (Element mono -> f (Element mono)) -> f mono
ofor = forall a b c. (a -> b -> c) -> b -> a -> c
flip forall mono (m :: * -> *).
(MonoTraversable mono, Applicative m) =>
(Element mono -> m (Element mono)) -> mono -> m mono
otraverse
{-# INLINE ofor #-}
oforM :: (MonoTraversable mono, Applicative f) => mono -> (Element mono -> f (Element mono)) -> f mono
oforM :: forall mono (f :: * -> *).
(MonoTraversable mono, Applicative f) =>
mono -> (Element mono -> f (Element mono)) -> f mono
oforM = forall a b c. (a -> b -> c) -> b -> a -> c
flip forall mono (m :: * -> *).
(MonoTraversable mono, Applicative m) =>
(Element mono -> m (Element mono)) -> mono -> m mono
omapM
{-# INLINE oforM #-}
ofoldlUnwrap :: MonoFoldable mono
=> (x -> Element mono -> x) -> x -> (x -> b) -> mono -> b
ofoldlUnwrap :: forall mono x b.
MonoFoldable mono =>
(x -> Element mono -> x) -> x -> (x -> b) -> mono -> b
ofoldlUnwrap x -> Element mono -> x
f x
x x -> b
unwrap mono
mono = x -> b
unwrap (forall mono a.
MonoFoldable mono =>
(a -> Element mono -> a) -> a -> mono -> a
ofoldl' x -> Element mono -> x
f x
x mono
mono)
ofoldMUnwrap :: (Monad m, MonoFoldable mono)
=> (x -> Element mono -> m x) -> m x -> (x -> m b) -> mono -> m b
ofoldMUnwrap :: forall (m :: * -> *) mono x b.
(Monad m, MonoFoldable mono) =>
(x -> Element mono -> m x) -> m x -> (x -> m b) -> mono -> m b
ofoldMUnwrap x -> Element mono -> m x
f m x
mx x -> m b
unwrap mono
mono = do
x
x <- m x
mx
x
x' <- forall mono (m :: * -> *) a.
(MonoFoldable mono, Monad m) =>
(a -> Element mono -> m a) -> a -> mono -> m a
ofoldlM x -> Element mono -> m x
f x
x mono
mono
x -> m b
unwrap x
x'
class MonoPointed mono where
opoint :: Element mono -> mono
default opoint :: (Applicative f, (f a) ~ mono, Element (f a) ~ a)
=> Element mono -> mono
opoint = forall (f :: * -> *) a. Applicative f => a -> f a
pure
{-# INLINE opoint #-}
instance MonoPointed S.ByteString where
opoint :: Element ByteString -> ByteString
opoint = Word8 -> ByteString
S.singleton
{-# INLINE opoint #-}
instance MonoPointed L.ByteString where
opoint :: Element ByteString -> ByteString
opoint = Word8 -> ByteString
L.singleton
{-# INLINE opoint #-}
instance MonoPointed T.Text where
opoint :: Element Text -> Text
opoint = Char -> Text
T.singleton
{-# INLINE opoint #-}
instance MonoPointed TL.Text where
opoint :: Element Text -> Text
opoint = Char -> Text
TL.singleton
{-# INLINE opoint #-}
instance MonoPointed [a]
instance MonoPointed (Maybe a)
#if !MIN_VERSION_base(4,16,0)
instance MonoPointed (Option a)
#endif
instance MonoPointed (NonEmpty a)
instance MonoPointed (Identity a)
instance MonoPointed (Vector a)
instance MonoPointed (IO a)
instance MonoPointed (ZipList a)
instance MonoPointed (r -> a)
instance Monoid a => MonoPointed (a, b)
instance Monoid m => MonoPointed (Const m a)
instance Monad m => MonoPointed (WrappedMonad m a)
#if !MIN_VERSION_transformers(0,6,0)
instance Applicative m => MonoPointed (ListT m a)
#endif
instance Applicative m => MonoPointed (IdentityT m a)
instance Arrow a => MonoPointed (WrappedArrow a b c)
instance (Monoid w, Applicative m) => MonoPointed (WriterT w m a)
instance (Monoid w, Applicative m) => MonoPointed (Strict.WriterT w m a)
instance Applicative m => MonoPointed (ReaderT r m a)
instance MonoPointed (ContT r m a)
instance (Applicative f, Applicative g) => MonoPointed (Compose f g a)
instance (Applicative f, Applicative g) => MonoPointed (Product f g a)
instance (Applicative f, Applicative g) => MonoPointed ((f :.: g) a)
instance (Applicative f, Applicative g) => MonoPointed ((f :*: g) a)
instance Applicative f => MonoPointed (M1 i c f a)
instance Applicative f => MonoPointed (Rec1 f a)
instance MonoPointed (Par1 a)
instance MonoPointed (U1 a)
instance MonoPointed (Proxy a)
instance MonoPointed (Seq a) where
opoint :: Element (Seq a) -> Seq a
opoint = forall a. a -> Seq a
Seq.singleton
{-# INLINE opoint #-}
instance U.Unbox a => MonoPointed (U.Vector a) where
opoint :: Element (Vector a) -> Vector a
opoint = forall a. Unbox a => a -> Vector a
U.singleton
{-# INLINE opoint #-}
instance VS.Storable a => MonoPointed (VS.Vector a) where
opoint :: Element (Vector a) -> Vector a
opoint = forall a. Storable a => a -> Vector a
VS.singleton
{-# INLINE opoint #-}
instance MonoPointed (Either a b) where
opoint :: Element (Either a b) -> Either a b
opoint = forall a b. b -> Either a b
Right
{-# INLINE opoint #-}
instance MonoPointed IntSet.IntSet where
opoint :: Element IntSet -> IntSet
opoint = Int -> IntSet
IntSet.singleton
{-# INLINE opoint #-}
instance MonoPointed (Set a) where
opoint :: Element (Set a) -> Set a
opoint = forall a. a -> Set a
Set.singleton
{-# INLINE opoint #-}
instance Hashable a => MonoPointed (HashSet a) where
opoint :: Element (HashSet a) -> HashSet a
opoint = forall a. Hashable a => a -> HashSet a
HashSet.singleton
{-# INLINE opoint #-}
instance Applicative f => MonoPointed (MaybeT f a) where
opoint :: Element (MaybeT f a) -> MaybeT f a
opoint = forall (m :: * -> *) a. m (Maybe a) -> MaybeT m a
MaybeT forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap forall a. a -> Maybe a
Just forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall (f :: * -> *) a. Applicative f => a -> f a
pure
{-# INLINE opoint #-}
instance (Monoid w, Applicative m) => MonoPointed (RWST r w s m a) where
opoint :: Element (RWST r w s m a) -> RWST r w s m a
opoint Element (RWST r w s m a)
a = forall r w s (m :: * -> *) a.
(r -> s -> m (a, s, w)) -> RWST r w s m a
RWST (\r
_ s
s -> forall (f :: * -> *) a. Applicative f => a -> f a
pure (Element (RWST r w s m a)
a, s
s, forall a. Monoid a => a
mempty))
{-# INLINE opoint #-}
instance (Monoid w, Applicative m) => MonoPointed (Strict.RWST r w s m a) where
opoint :: Element (RWST r w s m a) -> RWST r w s m a
opoint Element (RWST r w s m a)
a = forall r w s (m :: * -> *) a.
(r -> s -> m (a, s, w)) -> RWST r w s m a
Strict.RWST (\r
_ s
s -> forall (f :: * -> *) a. Applicative f => a -> f a
pure (Element (RWST r w s m a)
a, s
s, forall a. Monoid a => a
mempty))
{-# INLINE opoint #-}
instance Applicative m => MonoPointed (StateT s m a) where
opoint :: Element (StateT s m a) -> StateT s m a
opoint Element (StateT s m a)
a = forall s (m :: * -> *) a. (s -> m (a, s)) -> StateT s m a
StateT (\s
s -> forall (f :: * -> *) a. Applicative f => a -> f a
pure (Element (StateT s m a)
a, s
s))
{-# INLINE opoint #-}
instance Applicative m => MonoPointed (Strict.StateT s m a) where
opoint :: Element (StateT s m a) -> StateT s m a
opoint Element (StateT s m a)
a = forall s (m :: * -> *) a. (s -> m (a, s)) -> StateT s m a
Strict.StateT (\s
s -> forall (f :: * -> *) a. Applicative f => a -> f a
pure (Element (StateT s m a)
a, s
s))
{-# INLINE opoint #-}
instance MonoPointed (ViewL a) where
opoint :: Element (ViewL a) -> ViewL a
opoint Element (ViewL a)
a = Element (ViewL a)
a forall a. a -> Seq a -> ViewL a
:< forall a. Seq a
Seq.empty
{-# INLINE opoint #-}
instance MonoPointed (ViewR a) where
opoint :: Element (ViewR a) -> ViewR a
opoint Element (ViewR a)
a = forall a. Seq a
Seq.empty forall a. Seq a -> a -> ViewR a
:> Element (ViewR a)
a
{-# INLINE opoint #-}
instance MonoPointed (Tree a) where
opoint :: Element (Tree a) -> Tree a
opoint Element (Tree a)
a = forall a. a -> [Tree a] -> Tree a
Node Element (Tree a)
a []
{-# INLINE opoint #-}
instance (Applicative f, Applicative g) => MonoPointed ((f :+: g) a) where
opoint :: Element ((:+:) f g a) -> (:+:) f g a
opoint = forall k (f :: k -> *) (g :: k -> *) (p :: k). g p -> (:+:) f g p
R1 forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall (f :: * -> *) a. Applicative f => a -> f a
pure
{-# INLINE opoint #-}
class MonoFunctor mono => MonoComonad mono where
:: mono -> Element mono
oextend :: (mono -> Element mono) -> mono -> mono
instance MonoComonad (ViewL a) where
oextract :: ViewL a -> Element (ViewL a)
oextract ~(a
x :< Seq a
_) = a
x
{-# INLINE oextract #-}
oextend :: (ViewL a -> Element (ViewL a)) -> ViewL a -> ViewL a
oextend ViewL a -> Element (ViewL a)
f w :: ViewL a
w@(~(a
_ :< Seq a
xxs)) =
ViewL a -> Element (ViewL a)
f ViewL a
w forall a. a -> Seq a -> ViewL a
:< case forall a. Seq a -> ViewL a
Seq.viewl Seq a
xxs of
ViewL a
EmptyL -> forall a. Seq a
Seq.empty
ViewL a
xs -> case forall mono.
MonoComonad mono =>
(mono -> Element mono) -> mono -> mono
oextend ViewL a -> Element (ViewL a)
f ViewL a
xs of
ViewL a
EmptyL -> forall a. Seq a
Seq.empty
a
y :< Seq a
ys -> a
y forall a. a -> Seq a -> Seq a
Seq.<| Seq a
ys
instance MonoComonad (ViewR a) where
oextract :: ViewR a -> Element (ViewR a)
oextract ~(Seq a
_ :> a
x) = a
x
{-# INLINE oextract #-}
oextend :: (ViewR a -> Element (ViewR a)) -> ViewR a -> ViewR a
oextend ViewR a -> Element (ViewR a)
f w :: ViewR a
w@(~(Seq a
xxs :> a
_)) =
(case forall a. Seq a -> ViewR a
Seq.viewr Seq a
xxs of
ViewR a
EmptyR -> forall a. Seq a
Seq.empty
ViewR a
xs -> case forall mono.
MonoComonad mono =>
(mono -> Element mono) -> mono -> mono
oextend ViewR a -> Element (ViewR a)
f ViewR a
xs of
ViewR a
EmptyR -> forall a. Seq a
Seq.empty
Seq a
ys :> a
y -> Seq a
ys forall a. Seq a -> a -> Seq a
Seq.|> a
y
) forall a. Seq a -> a -> ViewR a
:> ViewR a -> Element (ViewR a)
f ViewR a
w
class MonoFoldable mono => GrowingAppend mono
instance GrowingAppend (Seq.Seq a)
instance GrowingAppend [a]
instance GrowingAppend (V.Vector a)
instance U.Unbox a => GrowingAppend (U.Vector a)
instance VS.Storable a => GrowingAppend (VS.Vector a)
instance GrowingAppend S.ByteString
instance GrowingAppend L.ByteString
instance GrowingAppend T.Text
instance GrowingAppend TL.Text
instance GrowingAppend (NonEmpty a)
instance Ord k => GrowingAppend (Map k v)
instance (Eq k, Hashable k) => GrowingAppend (HashMap k v)
instance Ord v => GrowingAppend (Set.Set v)
instance (Eq v, Hashable v) => GrowingAppend (HashSet.HashSet v)
instance GrowingAppend IntSet.IntSet
instance GrowingAppend (IntMap v)
ointercalate :: (MonoFoldable mono, Monoid (Element mono))
=> Element mono
-> mono
-> Element mono
ointercalate :: forall mono.
(MonoFoldable mono, Monoid (Element mono)) =>
Element mono -> mono -> Element mono
ointercalate Element mono
x = forall a. Monoid a => [a] -> a
mconcat forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall a. a -> [a] -> [a]
List.intersperse Element mono
x forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono. MonoFoldable mono => mono -> [Element mono]
otoList
{-# INLINE [0] ointercalate #-}
{-# RULES "ointercalate list" forall x.
ointercalate x = List.intercalate x . otoList #-}
{-# RULES "intercalate ByteString" forall x.
ointercalate x = S.intercalate x . otoList #-}
{-# RULES "intercalate LByteString" forall x.
ointercalate x = L.intercalate x . otoList #-}
{-# RULES "intercalate Text" forall x.
ointercalate x = T.intercalate x . otoList #-}
{-# RULES "intercalate LText" forall x.
ointercalate x = TL.intercalate x . otoList #-}
newtype WrappedPoly f a = WrappedPoly { forall (f :: * -> *) a. WrappedPoly f a -> f a
unwrapPoly :: f a }
deriving newtype (forall a. Eq a => a -> WrappedPoly f a -> Bool
forall a. Num a => WrappedPoly f a -> a
forall a. Ord a => WrappedPoly f a -> a
forall m. Monoid m => WrappedPoly f m -> m
forall a. WrappedPoly f a -> Bool
forall a. WrappedPoly f a -> Int
forall a. WrappedPoly f a -> [a]
forall a. (a -> a -> a) -> WrappedPoly f a -> a
forall m a. Monoid m => (a -> m) -> WrappedPoly f a -> m
forall b a. (b -> a -> b) -> b -> WrappedPoly f a -> b
forall a b. (a -> b -> b) -> b -> WrappedPoly f a -> b
forall (f :: * -> *) a.
(Foldable f, Eq a) =>
a -> WrappedPoly f a -> Bool
forall (f :: * -> *) a. (Foldable f, Num a) => WrappedPoly f a -> a
forall (f :: * -> *) a. (Foldable f, Ord a) => WrappedPoly f a -> a
forall (f :: * -> *) m.
(Foldable f, Monoid m) =>
WrappedPoly f m -> m
forall (f :: * -> *) a. Foldable f => WrappedPoly f a -> Bool
forall (f :: * -> *) a. Foldable f => WrappedPoly f a -> Int
forall (f :: * -> *) a. Foldable f => WrappedPoly f a -> [a]
forall (f :: * -> *) a.
Foldable f =>
(a -> a -> a) -> WrappedPoly f a -> a
forall (f :: * -> *) m a.
(Foldable f, Monoid m) =>
(a -> m) -> WrappedPoly f a -> m
forall (f :: * -> *) b a.
Foldable f =>
(b -> a -> b) -> b -> WrappedPoly f a -> b
forall (f :: * -> *) a b.
Foldable f =>
(a -> b -> b) -> b -> WrappedPoly f a -> b
forall (t :: * -> *).
(forall m. Monoid m => t m -> m)
-> (forall m a. Monoid m => (a -> m) -> t a -> m)
-> (forall m a. Monoid m => (a -> m) -> t a -> m)
-> (forall a b. (a -> b -> b) -> b -> t a -> b)
-> (forall a b. (a -> b -> b) -> b -> t a -> b)
-> (forall b a. (b -> a -> b) -> b -> t a -> b)
-> (forall b a. (b -> a -> b) -> b -> t a -> b)
-> (forall a. (a -> a -> a) -> t a -> a)
-> (forall a. (a -> a -> a) -> t a -> a)
-> (forall a. t a -> [a])
-> (forall a. t a -> Bool)
-> (forall a. t a -> Int)
-> (forall a. Eq a => a -> t a -> Bool)
-> (forall a. Ord a => t a -> a)
-> (forall a. Ord a => t a -> a)
-> (forall a. Num a => t a -> a)
-> (forall a. Num a => t a -> a)
-> Foldable t
product :: forall a. Num a => WrappedPoly f a -> a
$cproduct :: forall (f :: * -> *) a. (Foldable f, Num a) => WrappedPoly f a -> a
sum :: forall a. Num a => WrappedPoly f a -> a
$csum :: forall (f :: * -> *) a. (Foldable f, Num a) => WrappedPoly f a -> a
minimum :: forall a. Ord a => WrappedPoly f a -> a
$cminimum :: forall (f :: * -> *) a. (Foldable f, Ord a) => WrappedPoly f a -> a
maximum :: forall a. Ord a => WrappedPoly f a -> a
$cmaximum :: forall (f :: * -> *) a. (Foldable f, Ord a) => WrappedPoly f a -> a
elem :: forall a. Eq a => a -> WrappedPoly f a -> Bool
$celem :: forall (f :: * -> *) a.
(Foldable f, Eq a) =>
a -> WrappedPoly f a -> Bool
length :: forall a. WrappedPoly f a -> Int
$clength :: forall (f :: * -> *) a. Foldable f => WrappedPoly f a -> Int
null :: forall a. WrappedPoly f a -> Bool
$cnull :: forall (f :: * -> *) a. Foldable f => WrappedPoly f a -> Bool
toList :: forall a. WrappedPoly f a -> [a]
$ctoList :: forall (f :: * -> *) a. Foldable f => WrappedPoly f a -> [a]
foldl1 :: forall a. (a -> a -> a) -> WrappedPoly f a -> a
$cfoldl1 :: forall (f :: * -> *) a.
Foldable f =>
(a -> a -> a) -> WrappedPoly f a -> a
foldr1 :: forall a. (a -> a -> a) -> WrappedPoly f a -> a
$cfoldr1 :: forall (f :: * -> *) a.
Foldable f =>
(a -> a -> a) -> WrappedPoly f a -> a
foldl' :: forall b a. (b -> a -> b) -> b -> WrappedPoly f a -> b
$cfoldl' :: forall (f :: * -> *) b a.
Foldable f =>
(b -> a -> b) -> b -> WrappedPoly f a -> b
foldl :: forall b a. (b -> a -> b) -> b -> WrappedPoly f a -> b
$cfoldl :: forall (f :: * -> *) b a.
Foldable f =>
(b -> a -> b) -> b -> WrappedPoly f a -> b
foldr' :: forall a b. (a -> b -> b) -> b -> WrappedPoly f a -> b
$cfoldr' :: forall (f :: * -> *) a b.
Foldable f =>
(a -> b -> b) -> b -> WrappedPoly f a -> b
foldr :: forall a b. (a -> b -> b) -> b -> WrappedPoly f a -> b
$cfoldr :: forall (f :: * -> *) a b.
Foldable f =>
(a -> b -> b) -> b -> WrappedPoly f a -> b
foldMap' :: forall m a. Monoid m => (a -> m) -> WrappedPoly f a -> m
$cfoldMap' :: forall (f :: * -> *) m a.
(Foldable f, Monoid m) =>
(a -> m) -> WrappedPoly f a -> m
foldMap :: forall m a. Monoid m => (a -> m) -> WrappedPoly f a -> m
$cfoldMap :: forall (f :: * -> *) m a.
(Foldable f, Monoid m) =>
(a -> m) -> WrappedPoly f a -> m
fold :: forall m. Monoid m => WrappedPoly f m -> m
$cfold :: forall (f :: * -> *) m.
(Foldable f, Monoid m) =>
WrappedPoly f m -> m
F.Foldable, forall a b. a -> WrappedPoly f b -> WrappedPoly f a
forall a b. (a -> b) -> WrappedPoly f a -> WrappedPoly f b
forall (f :: * -> *) a b.
Functor f =>
a -> WrappedPoly f b -> WrappedPoly f a
forall (f :: * -> *) a b.
Functor f =>
(a -> b) -> WrappedPoly f a -> WrappedPoly f b
forall (f :: * -> *).
(forall a b. (a -> b) -> f a -> f b)
-> (forall a b. a -> f b -> f a) -> Functor f
<$ :: forall a b. a -> WrappedPoly f b -> WrappedPoly f a
$c<$ :: forall (f :: * -> *) a b.
Functor f =>
a -> WrappedPoly f b -> WrappedPoly f a
fmap :: forall a b. (a -> b) -> WrappedPoly f a -> WrappedPoly f b
$cfmap :: forall (f :: * -> *) a b.
Functor f =>
(a -> b) -> WrappedPoly f a -> WrappedPoly f b
Functor, forall a. a -> WrappedPoly f a
forall a b. WrappedPoly f a -> WrappedPoly f b -> WrappedPoly f a
forall a b. WrappedPoly f a -> WrappedPoly f b -> WrappedPoly f b
forall a b.
WrappedPoly f (a -> b) -> WrappedPoly f a -> WrappedPoly f b
forall a b c.
(a -> b -> c)
-> WrappedPoly f a -> WrappedPoly f b -> WrappedPoly f c
forall (f :: * -> *).
Functor f
-> (forall a. a -> f a)
-> (forall a b. f (a -> b) -> f a -> f b)
-> (forall a b c. (a -> b -> c) -> f a -> f b -> f c)
-> (forall a b. f a -> f b -> f b)
-> (forall a b. f a -> f b -> f a)
-> Applicative f
forall {f :: * -> *}. Applicative f => Functor (WrappedPoly f)
forall (f :: * -> *) a. Applicative f => a -> WrappedPoly f a
forall (f :: * -> *) a b.
Applicative f =>
WrappedPoly f a -> WrappedPoly f b -> WrappedPoly f a
forall (f :: * -> *) a b.
Applicative f =>
WrappedPoly f a -> WrappedPoly f b -> WrappedPoly f b
forall (f :: * -> *) a b.
Applicative f =>
WrappedPoly f (a -> b) -> WrappedPoly f a -> WrappedPoly f b
forall (f :: * -> *) a b c.
Applicative f =>
(a -> b -> c)
-> WrappedPoly f a -> WrappedPoly f b -> WrappedPoly f c
<* :: forall a b. WrappedPoly f a -> WrappedPoly f b -> WrappedPoly f a
$c<* :: forall (f :: * -> *) a b.
Applicative f =>
WrappedPoly f a -> WrappedPoly f b -> WrappedPoly f a
*> :: forall a b. WrappedPoly f a -> WrappedPoly f b -> WrappedPoly f b
$c*> :: forall (f :: * -> *) a b.
Applicative f =>
WrappedPoly f a -> WrappedPoly f b -> WrappedPoly f b
liftA2 :: forall a b c.
(a -> b -> c)
-> WrappedPoly f a -> WrappedPoly f b -> WrappedPoly f c
$cliftA2 :: forall (f :: * -> *) a b c.
Applicative f =>
(a -> b -> c)
-> WrappedPoly f a -> WrappedPoly f b -> WrappedPoly f c
<*> :: forall a b.
WrappedPoly f (a -> b) -> WrappedPoly f a -> WrappedPoly f b
$c<*> :: forall (f :: * -> *) a b.
Applicative f =>
WrappedPoly f (a -> b) -> WrappedPoly f a -> WrappedPoly f b
pure :: forall a. a -> WrappedPoly f a
$cpure :: forall (f :: * -> *) a. Applicative f => a -> WrappedPoly f a
Applicative, forall a. a -> WrappedPoly f a
forall a b. WrappedPoly f a -> WrappedPoly f b -> WrappedPoly f b
forall a b.
WrappedPoly f a -> (a -> WrappedPoly f b) -> WrappedPoly f b
forall {f :: * -> *}. Monad f => Applicative (WrappedPoly f)
forall (f :: * -> *) a. Monad f => a -> WrappedPoly f a
forall (f :: * -> *) a b.
Monad f =>
WrappedPoly f a -> WrappedPoly f b -> WrappedPoly f b
forall (f :: * -> *) a b.
Monad f =>
WrappedPoly f a -> (a -> WrappedPoly f b) -> WrappedPoly f b
forall (m :: * -> *).
Applicative m
-> (forall a b. m a -> (a -> m b) -> m b)
-> (forall a b. m a -> m b -> m b)
-> (forall a. a -> m a)
-> Monad m
return :: forall a. a -> WrappedPoly f a
$creturn :: forall (f :: * -> *) a. Monad f => a -> WrappedPoly f a
>> :: forall a b. WrappedPoly f a -> WrappedPoly f b -> WrappedPoly f b
$c>> :: forall (f :: * -> *) a b.
Monad f =>
WrappedPoly f a -> WrappedPoly f b -> WrappedPoly f b
>>= :: forall a b.
WrappedPoly f a -> (a -> WrappedPoly f b) -> WrappedPoly f b
$c>>= :: forall (f :: * -> *) a b.
Monad f =>
WrappedPoly f a -> (a -> WrappedPoly f b) -> WrappedPoly f b
Monad)
type instance Element (WrappedPoly f a) = a
instance F.Foldable f => MonoFoldable (WrappedPoly f a)
instance Functor f => MonoFunctor (WrappedPoly f a)
instance Applicative f => MonoPointed (WrappedPoly f a)
data WrappedMono mono a where
WrappedMono :: Element mono ~ a => mono -> WrappedMono mono a
unwrapMono :: WrappedMono mono a -> mono
unwrapMono :: forall mono a. WrappedMono mono a -> mono
unwrapMono (WrappedMono mono
mono) = mono
mono
{-# INLINE unwrapMono #-}
type instance Element (WrappedMono mono a) = Element mono
instance MonoFoldable mono => MonoFoldable (WrappedMono mono a) where
ofoldMap :: forall m.
Monoid m =>
(Element (WrappedMono mono a) -> m) -> WrappedMono mono a -> m
ofoldMap Element (WrappedMono mono a) -> m
f = forall mono m.
(MonoFoldable mono, Monoid m) =>
(Element mono -> m) -> mono -> m
ofoldMap Element (WrappedMono mono a) -> m
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE ofoldMap #-}
ofoldr :: forall b.
(Element (WrappedMono mono a) -> b -> b)
-> b -> WrappedMono mono a -> b
ofoldr Element (WrappedMono mono a) -> b -> b
f b
z = forall mono b.
MonoFoldable mono =>
(Element mono -> b -> b) -> b -> mono -> b
ofoldr Element (WrappedMono mono a) -> b -> b
f b
z forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE ofoldr #-}
ofoldl' :: forall a.
(a -> Element (WrappedMono mono a) -> a)
-> a -> WrappedMono mono a -> a
ofoldl' a -> Element (WrappedMono mono a) -> a
f a
z = forall mono a.
MonoFoldable mono =>
(a -> Element mono -> a) -> a -> mono -> a
ofoldl' a -> Element (WrappedMono mono a) -> a
f a
z forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE ofoldl' #-}
otoList :: WrappedMono mono a -> [Element (WrappedMono mono a)]
otoList = forall mono. MonoFoldable mono => mono -> [Element mono]
otoList forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE otoList #-}
oall :: (Element (WrappedMono mono a) -> Bool)
-> WrappedMono mono a -> Bool
oall Element (WrappedMono mono a) -> Bool
f = forall mono.
MonoFoldable mono =>
(Element mono -> Bool) -> mono -> Bool
oall Element (WrappedMono mono a) -> Bool
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE oall #-}
oany :: (Element (WrappedMono mono a) -> Bool)
-> WrappedMono mono a -> Bool
oany Element (WrappedMono mono a) -> Bool
f = forall mono.
MonoFoldable mono =>
(Element mono -> Bool) -> mono -> Bool
oany Element (WrappedMono mono a) -> Bool
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE oany #-}
onull :: WrappedMono mono a -> Bool
onull = forall mono. MonoFoldable mono => mono -> Bool
onull forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE onull #-}
olength :: WrappedMono mono a -> Int
olength = forall mono. MonoFoldable mono => mono -> Int
olength forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE olength #-}
olength64 :: WrappedMono mono a -> Int64
olength64 = forall mono. MonoFoldable mono => mono -> Int64
olength64 forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE olength64 #-}
ocompareLength :: forall i. Integral i => WrappedMono mono a -> i -> Ordering
ocompareLength WrappedMono mono a
mono i
i = forall mono i.
(MonoFoldable mono, Integral i) =>
mono -> i -> Ordering
ocompareLength (forall mono a. WrappedMono mono a -> mono
unwrapMono WrappedMono mono a
mono) i
i
{-# INLINE ocompareLength #-}
otraverse_ :: forall (f :: * -> *) b.
Applicative f =>
(Element (WrappedMono mono a) -> f b) -> WrappedMono mono a -> f ()
otraverse_ Element (WrappedMono mono a) -> f b
f = forall mono (f :: * -> *) b.
(MonoFoldable mono, Applicative f) =>
(Element mono -> f b) -> mono -> f ()
otraverse_ Element (WrappedMono mono a) -> f b
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE otraverse_ #-}
ofor_ :: forall (f :: * -> *) b.
Applicative f =>
WrappedMono mono a -> (Element (WrappedMono mono a) -> f b) -> f ()
ofor_ WrappedMono mono a
mono Element (WrappedMono mono a) -> f b
f = forall mono (f :: * -> *) b.
(MonoFoldable mono, Applicative f) =>
mono -> (Element mono -> f b) -> f ()
ofor_ (forall mono a. WrappedMono mono a -> mono
unwrapMono WrappedMono mono a
mono) Element (WrappedMono mono a) -> f b
f
{-# INLINE ofor_ #-}
omapM_ :: forall (m :: * -> *).
Applicative m =>
(Element (WrappedMono mono a) -> m ())
-> WrappedMono mono a -> m ()
omapM_ Element (WrappedMono mono a) -> m ()
f = forall mono (m :: * -> *).
(MonoFoldable mono, Applicative m) =>
(Element mono -> m ()) -> mono -> m ()
omapM_ Element (WrappedMono mono a) -> m ()
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE omapM_ #-}
oforM_ :: forall (m :: * -> *).
Applicative m =>
WrappedMono mono a
-> (Element (WrappedMono mono a) -> m ()) -> m ()
oforM_ WrappedMono mono a
mono Element (WrappedMono mono a) -> m ()
f = forall mono (m :: * -> *).
(MonoFoldable mono, Applicative m) =>
mono -> (Element mono -> m ()) -> m ()
oforM_ (forall mono a. WrappedMono mono a -> mono
unwrapMono WrappedMono mono a
mono) Element (WrappedMono mono a) -> m ()
f
{-# INLINE oforM_ #-}
ofoldlM :: forall (m :: * -> *) a.
Monad m =>
(a -> Element (WrappedMono mono a) -> m a)
-> a -> WrappedMono mono a -> m a
ofoldlM a -> Element (WrappedMono mono a) -> m a
f a
z = forall mono (m :: * -> *) a.
(MonoFoldable mono, Monad m) =>
(a -> Element mono -> m a) -> a -> mono -> m a
ofoldlM a -> Element (WrappedMono mono a) -> m a
f a
z forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE ofoldlM #-}
ofoldMap1Ex :: forall m.
Semigroup m =>
(Element (WrappedMono mono a) -> m) -> WrappedMono mono a -> m
ofoldMap1Ex Element (WrappedMono mono a) -> m
f = forall mono m.
(MonoFoldable mono, Semigroup m) =>
(Element mono -> m) -> mono -> m
ofoldMap1Ex Element (WrappedMono mono a) -> m
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE ofoldMap1Ex #-}
ofoldr1Ex :: (Element (WrappedMono mono a)
-> Element (WrappedMono mono a) -> Element (WrappedMono mono a))
-> WrappedMono mono a -> Element (WrappedMono mono a)
ofoldr1Ex Element (WrappedMono mono a)
-> Element (WrappedMono mono a) -> Element (WrappedMono mono a)
f = forall mono.
MonoFoldable mono =>
(Element mono -> Element mono -> Element mono)
-> mono -> Element mono
ofoldr1Ex Element (WrappedMono mono a)
-> Element (WrappedMono mono a) -> Element (WrappedMono mono a)
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE ofoldr1Ex #-}
ofoldl1Ex' :: (Element (WrappedMono mono a)
-> Element (WrappedMono mono a) -> Element (WrappedMono mono a))
-> WrappedMono mono a -> Element (WrappedMono mono a)
ofoldl1Ex' Element (WrappedMono mono a)
-> Element (WrappedMono mono a) -> Element (WrappedMono mono a)
f = forall mono.
MonoFoldable mono =>
(Element mono -> Element mono -> Element mono)
-> mono -> Element mono
ofoldl1Ex' Element (WrappedMono mono a)
-> Element (WrappedMono mono a) -> Element (WrappedMono mono a)
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE ofoldl1Ex' #-}
headEx :: WrappedMono mono a -> Element (WrappedMono mono a)
headEx = forall mono. MonoFoldable mono => mono -> Element mono
headEx forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE headEx #-}
lastEx :: WrappedMono mono a -> Element (WrappedMono mono a)
lastEx = forall mono. MonoFoldable mono => mono -> Element mono
lastEx forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE lastEx #-}
unsafeHead :: WrappedMono mono a -> Element (WrappedMono mono a)
unsafeHead = forall mono. MonoFoldable mono => mono -> Element mono
unsafeHead forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE unsafeHead #-}
unsafeLast :: WrappedMono mono a -> Element (WrappedMono mono a)
unsafeLast = forall mono. MonoFoldable mono => mono -> Element mono
unsafeLast forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE unsafeLast #-}
maximumByEx :: (Element (WrappedMono mono a)
-> Element (WrappedMono mono a) -> Ordering)
-> WrappedMono mono a -> Element (WrappedMono mono a)
maximumByEx Element (WrappedMono mono a)
-> Element (WrappedMono mono a) -> Ordering
f = forall mono.
MonoFoldable mono =>
(Element mono -> Element mono -> Ordering) -> mono -> Element mono
maximumByEx Element (WrappedMono mono a)
-> Element (WrappedMono mono a) -> Ordering
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE maximumByEx #-}
minimumByEx :: (Element (WrappedMono mono a)
-> Element (WrappedMono mono a) -> Ordering)
-> WrappedMono mono a -> Element (WrappedMono mono a)
minimumByEx Element (WrappedMono mono a)
-> Element (WrappedMono mono a) -> Ordering
f = forall mono.
MonoFoldable mono =>
(Element mono -> Element mono -> Ordering) -> mono -> Element mono
minimumByEx Element (WrappedMono mono a)
-> Element (WrappedMono mono a) -> Ordering
f forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE minimumByEx #-}
oelem :: Eq (Element (WrappedMono mono a)) =>
Element (WrappedMono mono a) -> WrappedMono mono a -> Bool
oelem Element (WrappedMono mono a)
a = forall mono.
(MonoFoldable mono, Eq (Element mono)) =>
Element mono -> mono -> Bool
oelem Element (WrappedMono mono a)
a forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE oelem #-}
onotElem :: Eq (Element (WrappedMono mono a)) =>
Element (WrappedMono mono a) -> WrappedMono mono a -> Bool
onotElem Element (WrappedMono mono a)
a = forall mono.
(MonoFoldable mono, Eq (Element mono)) =>
Element mono -> mono -> Bool
onotElem Element (WrappedMono mono a)
a forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. forall mono a. WrappedMono mono a -> mono
unwrapMono
{-# INLINE onotElem #-}
instance MonoFunctor mono => MonoFunctor (WrappedMono mono a) where
omap :: (Element (WrappedMono mono a) -> Element (WrappedMono mono a))
-> WrappedMono mono a -> WrappedMono mono a
omap Element (WrappedMono mono a) -> Element (WrappedMono mono a)
f (WrappedMono mono
mono) = forall mono a. (Element mono ~ a) => mono -> WrappedMono mono a
WrappedMono (forall mono.
MonoFunctor mono =>
(Element mono -> Element mono) -> mono -> mono
omap Element (WrappedMono mono a) -> Element (WrappedMono mono a)
f mono
mono)
{-# INLINE omap #-}
instance (MonoPointed mono, Element mono ~ a) => MonoPointed (WrappedMono mono a) where
opoint :: Element (WrappedMono mono a) -> WrappedMono mono a
opoint Element (WrappedMono mono a)
a = forall mono a. (Element mono ~ a) => mono -> WrappedMono mono a
WrappedMono (forall mono. MonoPointed mono => Element mono -> mono
opoint Element (WrappedMono mono a)
a)
{-# INLINE opoint #-}
instance MonoFoldable mono => F.Foldable (WrappedMono mono) where
foldr :: forall a b. (a -> b -> b) -> b -> WrappedMono mono a -> b
foldr a -> b -> b
f b
zero (WrappedMono mono
mono) = forall mono b.
MonoFoldable mono =>
(Element mono -> b -> b) -> b -> mono -> b
ofoldr a -> b -> b
f b
zero mono
mono
{-# INLINE foldr #-}
foldMap :: forall m a. Monoid m => (a -> m) -> WrappedMono mono a -> m
foldMap a -> m
f (WrappedMono mono
mono) = forall mono m.
(MonoFoldable mono, Monoid m) =>
(Element mono -> m) -> mono -> m
ofoldMap a -> m
f mono
mono
{-# INLINE foldMap #-}
foldl' :: forall b a. (b -> a -> b) -> b -> WrappedMono mono a -> b
foldl' b -> a -> b
f b
z (WrappedMono mono
mono) = forall mono a.
MonoFoldable mono =>
(a -> Element mono -> a) -> a -> mono -> a
ofoldl' b -> a -> b
f b
z mono
mono
{-# INLINE foldl' #-}
foldl1 :: forall a. (a -> a -> a) -> WrappedMono mono a -> a
foldl1 a -> a -> a
f (WrappedMono mono
mono) = forall mono.
MonoFoldable mono =>
(Element mono -> Element mono -> Element mono)
-> mono -> Element mono
ofoldl1Ex' a -> a -> a
f mono
mono
{-# INLINE foldl1 #-}
toList :: forall a. WrappedMono mono a -> [a]
toList (WrappedMono mono
mono) = forall mono. MonoFoldable mono => mono -> [Element mono]
otoList mono
mono
{-# INLINE toList #-}
null :: forall a. WrappedMono mono a -> Bool
null (WrappedMono mono
mono) = forall mono. MonoFoldable mono => mono -> Bool
onull mono
mono
{-# INLINE null #-}
length :: forall a. WrappedMono mono a -> Int
length (WrappedMono mono
mono) = forall mono. MonoFoldable mono => mono -> Int
olength mono
mono
{-# INLINE length #-}
elem :: forall a. Eq a => a -> WrappedMono mono a -> Bool
elem a
a (WrappedMono mono
mono) = forall mono.
(MonoFoldable mono, Eq (Element mono)) =>
Element mono -> mono -> Bool
oelem a
a mono
mono
{-# INLINE elem #-}
maximum :: forall a. Ord a => WrappedMono mono a -> a
maximum (WrappedMono mono
mono) = forall mono.
(MonoFoldable mono, Ord (Element mono)) =>
mono -> Element mono
maximumEx mono
mono
{-# INLINE maximum #-}
minimum :: forall a. Ord a => WrappedMono mono a -> a
minimum (WrappedMono mono
mono) = forall mono.
(MonoFoldable mono, Ord (Element mono)) =>
mono -> Element mono
minimumEx mono
mono
{-# INLINE minimum #-}