{-# LANGUAGE CPP #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE TypeFamilies #-}
{-# OPTIONS_GHC -fno-warn-orphans #-}
module Data.RAVec.Tree.DF.Lens (
ix,
) where
import Control.Applicative ((<$>))
import Data.Wrd (Wrd (..))
import Prelude ()
import qualified Control.Lens as L
import qualified Data.Type.Nat as N
import Data.RAVec.Tree.DF
ix :: Wrd n -> L.Lens' (Tree n a) a
ix :: Wrd n -> Lens' (Tree n a) a
ix Wrd n
WE a -> f a
f (Leaf x) = a -> Tree 'Z a
forall a. a -> Tree 'Z a
Leaf (a -> Tree 'Z a) -> f a -> f (Tree 'Z a)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> a -> f a
f a
x
ix (W0 Wrd n1
is) a -> f a
f (Node x y) = (Tree n1 a -> Tree n1 a -> Tree ('S n1) a
forall (n :: Nat) a. Tree n a -> Tree n a -> Tree ('S n) a
`Node` Tree n1 a
y) (Tree n1 a -> Tree ('S n1) a)
-> f (Tree n1 a) -> f (Tree ('S n1) a)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Wrd n1 -> (a -> f a) -> Tree n1 a -> f (Tree n1 a)
forall (n :: Nat) a. Wrd n -> Lens' (Tree n a) a
ix Wrd n1
is a -> f a
f Tree n1 a
x
ix (W1 Wrd n1
is) a -> f a
f (Node x y) = (Tree n1 a
x Tree n1 a -> Tree n1 a -> Tree ('S n1) a
forall (n :: Nat) a. Tree n a -> Tree n a -> Tree ('S n) a
`Node`) (Tree n1 a -> Tree ('S n1) a)
-> f (Tree n1 a) -> f (Tree ('S n1) a)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Wrd n1 -> (a -> f a) -> Tree n1 a -> f (Tree n1 a)
forall (n :: Nat) a. Wrd n -> Lens' (Tree n a) a
ix Wrd n1
is a -> f a
f Tree n1 a
y
#if !MIN_VERSION_lens(5,0,0)
instance N.SNatI n => L.FunctorWithIndex (Wrd n) (Tree n) where
imap = imap
instance N.SNatI n => L.FoldableWithIndex (Wrd n) (Tree n) where
ifoldMap = ifoldMap
ifoldr = ifoldr
ifoldl = ifoldl
instance N.SNatI n => L.TraversableWithIndex (Wrd n) (Tree n) where
itraverse = itraverse
#endif
instance N.SNatI n => L.Each (Tree n a) (Tree n b) a b
type instance L.Index (Tree n a) = Wrd n
type instance L.IxValue (Tree n a) = a
instance L.Ixed (Tree n a) where
ix :: Index (Tree n a) -> Traversal' (Tree n a) (IxValue (Tree n a))
ix Index (Tree n a)
i = Wrd n -> Lens' (Tree n a) a
forall (n :: Nat) a. Wrd n -> Lens' (Tree n a) a
ix Wrd n
Index (Tree n a)
i