Source code on Github{-# OPTIONS --cubical-compatible #-}
module Class.Applicative.Core where
open import Class.Prelude
open import Class.Core
open import Class.Functor.Core
record Applicative (F : Type↑) : Typeω where
infixl 4 _<*>_ _⊛_ _<*_ _<⊛_ _*>_ _⊛>_
infix 4 _⊗_
field
overlap ⦃ super ⦄ : Functor F
pure : A → F A
_<*>_ : F (A → B) → F A → F B
_⊛_ = _<*>_
_<*_ : F A → F B → F A
x <* y = const <$> x ⊛ y
_*>_ : F A → F B → F B
x *> y = constᵣ <$> x ⊛ y
_<⊛_ = _<*_; _⊛>_ = _*>_
_⊗_ : F A → F B → F (A × B)
x ⊗ y = (_,_) <$> x ⊛ y
zipWithA : (A → B → C) → F A → F B → F C
zipWithA f x y = f <$> x ⊛ y
zipA : F A → F B → F (A × B)
zipA = zipWithA _,_
open Applicative ⦃...⦄ public
record Applicative₀ (F : Type↑) : Typeω where
field
overlap ⦃ super ⦄ : Applicative F
ε₀ : F A
open Applicative₀ ⦃...⦄ public
record Alternative (F : Type↑) : Typeω where
infixr 3 _<|>_
field _<|>_ : F A → F A → F A
open Alternative ⦃...⦄ public
infix -1 ⋃⁺_ ⋃_
⋃⁺_ : ⦃ Alternative F ⦄ → List⁺ (F A) → F A
⋃⁺_ = foldr₁ _<|>_
⋃_ : ⦃ Applicative₀ F ⦄ → ⦃ Alternative F ⦄ → List (F A) → F A
⋃_ = foldr _<|>_ ε₀