{-# LANGUAGE Trustworthy #-}
{-# LANGUAGE LambdaCase #-}
module Data.Extensible.Plain (
    AllOf
  , OneOf
  , (<%)
  , pluck
  , bury
  , (<%|)
  , accessing
  ) where
import Data.Extensible.Internal.Rig
import Data.Extensible.Class
import Data.Extensible.Product
import Data.Extensible.Sum
import Data.Functor.Identity
import Data.Extensible.Wrapper
import Data.Coerce
import Data.Profunctor.Unsafe
type AllOf xs = xs :& Identity
type OneOf xs = xs :/ Identity
(<%) :: x -> AllOf xs -> AllOf (x ': xs)
<% :: x -> AllOf xs -> AllOf (x : xs)
(<%) = Identity x -> AllOf xs -> AllOf (x : xs)
forall k (h :: k -> Type) (x :: k) (xs :: [k]).
h x -> (xs :& h) -> (x : xs) :& h
(<:) (Identity x -> AllOf xs -> AllOf (x : xs))
-> (x -> Identity x) -> x -> AllOf xs -> AllOf (x : xs)
forall (p :: Type -> Type -> Type) a b c
       (q :: Type -> Type -> Type).
(Profunctor p, Coercible b a) =>
p b c -> q a b -> p a c
.# x -> Identity x
forall a. a -> Identity a
Identity
{-# INLINE (<%) #-}
infixr 5 <%
pluck :: (x ∈ xs) => AllOf xs -> x
pluck :: AllOf xs -> x
pluck = Optic' (->) (Const x) (AllOf xs) (Identity x)
-> (Identity x -> x) -> AllOf xs -> x
forall r s a. Optic' (->) (Const r) s a -> (a -> r) -> s -> r
views Optic' (->) (Const x) (AllOf xs) (Identity x)
forall k (x :: k) (xs :: [k]) (f :: Type -> Type)
       (p :: Type -> Type -> Type) (t :: [k] -> (k -> Type) -> Type)
       (h :: k -> Type).
(x ∈ xs, Extensible f p t, ExtensibleConstr t xs h x) =>
Optic' p f (t xs h) (h x)
piece Identity x -> x
forall a. Identity a -> a
runIdentity
{-# INLINE pluck #-}
bury :: (x ∈ xs) => x -> OneOf xs
bury :: x -> OneOf xs
bury = Identity x -> OneOf xs
forall k (x :: k) (xs :: [k]) (h :: k -> Type).
(x ∈ xs) =>
h x -> xs :/ h
embed (Identity x -> OneOf xs) -> (x -> Identity x) -> x -> OneOf xs
forall (p :: Type -> Type -> Type) a b c
       (q :: Type -> Type -> Type).
(Profunctor p, Coercible b a) =>
p b c -> q a b -> p a c
.# x -> Identity x
forall a. a -> Identity a
Identity
{-# INLINE bury #-}
(<%|) :: (x -> r) -> (OneOf xs -> r) -> OneOf (x ': xs) -> r
<%| :: (x -> r) -> (OneOf xs -> r) -> OneOf (x : xs) -> r
(<%|) = (Identity x -> r) -> (OneOf xs -> r) -> OneOf (x : xs) -> r
forall k (h :: k -> Type) (x :: k) r (xs :: [k]).
(h x -> r) -> ((xs :/ h) -> r) -> ((x : xs) :/ h) -> r
(<:|) ((Identity x -> r) -> (OneOf xs -> r) -> OneOf (x : xs) -> r)
-> ((x -> r) -> Identity x -> r)
-> (x -> r)
-> (OneOf xs -> r)
-> OneOf (x : xs)
-> r
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ((x -> r) -> (Identity x -> x) -> Identity x -> r
forall (p :: Type -> Type -> Type) a b c
       (q :: Type -> Type -> Type).
(Profunctor p, Coercible b a) =>
p b c -> q a b -> p a c
.# Identity x -> x
forall a. Identity a -> a
runIdentity)
infixr 1 <%|
accessing :: (Coercible x a, x ∈ xs, Extensible f p t, ExtensibleConstr t xs Identity x) => (a -> x) -> Optic' p f (t xs Identity) a
accessing :: (a -> x) -> Optic' p f (t xs Identity) a
accessing a -> x
c = Optic' p f (t xs Identity) (Identity x)
forall k (x :: k) (xs :: [k]) (f :: Type -> Type)
       (p :: Type -> Type -> Type) (t :: [k] -> (k -> Type) -> Type)
       (h :: k -> Type).
(x ∈ xs, Extensible f p t, ExtensibleConstr t xs h x) =>
Optic' p f (t xs h) (h x)
piece Optic' p f (t xs Identity) (Identity x)
-> (p a (f a) -> p (Identity x) (f (Identity x)))
-> Optic' p f (t xs Identity) a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. p x (f x) -> p (Identity x) (f (Identity x))
forall k (h :: k -> Type) (f :: Type -> Type)
       (p :: Type -> Type -> Type) (v :: k).
(Wrapper h, Functor f, Profunctor p) =>
Optic' p f (h v) (Repr h v)
_Wrapper (p x (f x) -> p (Identity x) (f (Identity x)))
-> (p a (f a) -> p x (f x))
-> p a (f a)
-> p (Identity x) (f (Identity x))
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (x -> a) -> (f a -> f x) -> p a (f a) -> p x (f x)
forall (p :: Type -> Type -> Type) a b c d.
Profunctor p =>
(a -> b) -> (c -> d) -> p b c -> p a d
dimap x -> a
coerce ((a -> x) -> f a -> f x
forall (f :: Type -> Type) a b. Functor f => (a -> b) -> f a -> f b
fmap a -> x
c)
{-# INLINE accessing #-}