module Control.Arrow.ArrowNavigatableTree
where
import Control.Arrow
import Control.Arrow.ArrowList
import Control.Arrow.ArrowIf
import Data.Maybe
import Data.Tree.NavigatableTree.Class ( NavigatableTree
, NavigatableTreeToTree
, NavigatableTreeModify
)
import qualified Data.Tree.NavigatableTree.Class as T
import qualified Data.Tree.NavigatableTree.XPathAxis as T
class (ArrowList a) => ArrowNavigatableTree a where
moveUp :: NavigatableTree t => a (t b) (t b)
moveUp = (t b -> [t b]) -> a (t b) (t b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL ((t b -> [t b]) -> a (t b) (t b))
-> (t b -> [t b]) -> a (t b) (t b)
forall a b. (a -> b) -> a -> b
$ Maybe (t b) -> [t b]
forall a. Maybe a -> [a]
maybeToList (Maybe (t b) -> [t b]) -> (t b -> Maybe (t b)) -> t b -> [t b]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. t b -> Maybe (t b)
forall a. t a -> Maybe (t a)
forall (t :: * -> *) a. NavigatableTree t => t a -> Maybe (t a)
T.mvUp
moveDown :: NavigatableTree t => a (t b) (t b)
moveDown = (t b -> [t b]) -> a (t b) (t b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL ((t b -> [t b]) -> a (t b) (t b))
-> (t b -> [t b]) -> a (t b) (t b)
forall a b. (a -> b) -> a -> b
$ Maybe (t b) -> [t b]
forall a. Maybe a -> [a]
maybeToList (Maybe (t b) -> [t b]) -> (t b -> Maybe (t b)) -> t b -> [t b]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. t b -> Maybe (t b)
forall a. t a -> Maybe (t a)
forall (t :: * -> *) a. NavigatableTree t => t a -> Maybe (t a)
T.mvDown
moveLeft :: NavigatableTree t => a (t b) (t b)
moveLeft = (t b -> [t b]) -> a (t b) (t b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL ((t b -> [t b]) -> a (t b) (t b))
-> (t b -> [t b]) -> a (t b) (t b)
forall a b. (a -> b) -> a -> b
$ Maybe (t b) -> [t b]
forall a. Maybe a -> [a]
maybeToList (Maybe (t b) -> [t b]) -> (t b -> Maybe (t b)) -> t b -> [t b]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. t b -> Maybe (t b)
forall a. t a -> Maybe (t a)
forall (t :: * -> *) a. NavigatableTree t => t a -> Maybe (t a)
T.mvLeft
moveRight :: NavigatableTree t => a (t b) (t b)
moveRight = (t b -> [t b]) -> a (t b) (t b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL ((t b -> [t b]) -> a (t b) (t b))
-> (t b -> [t b]) -> a (t b) (t b)
forall a b. (a -> b) -> a -> b
$ Maybe (t b) -> [t b]
forall a. Maybe a -> [a]
maybeToList (Maybe (t b) -> [t b]) -> (t b -> Maybe (t b)) -> t b -> [t b]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. t b -> Maybe (t b)
forall a. t a -> Maybe (t a)
forall (t :: * -> *) a. NavigatableTree t => t a -> Maybe (t a)
T.mvRight
parentAxis :: (ArrowList a, NavigatableTree t) => a (t b) (t b)
parentAxis :: forall (a :: * -> * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTree t) =>
a (t b) (t b)
parentAxis = (t b -> [t b]) -> a (t b) (t b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL t b -> [t b]
forall (t :: * -> *) a. NavigatableTree t => t a -> [t a]
T.parentAxis
ancestorAxis :: (ArrowList a, NavigatableTree t) => a (t b) (t b)
ancestorAxis :: forall (a :: * -> * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTree t) =>
a (t b) (t b)
ancestorAxis = (t b -> [t b]) -> a (t b) (t b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL t b -> [t b]
forall (t :: * -> *) a. NavigatableTree t => t a -> [t a]
T.ancestorAxis
ancestorOrSelfAxis :: (ArrowList a, NavigatableTree t) => a (t b) (t b)
ancestorOrSelfAxis :: forall (a :: * -> * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTree t) =>
a (t b) (t b)
ancestorOrSelfAxis = (t b -> [t b]) -> a (t b) (t b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL t b -> [t b]
forall (t :: * -> *) a. NavigatableTree t => t a -> [t a]
T.ancestorOrSelfAxis
childAxis :: (ArrowList a, NavigatableTree t) => a (t b) (t b)
childAxis :: forall (a :: * -> * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTree t) =>
a (t b) (t b)
childAxis = (t b -> [t b]) -> a (t b) (t b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL t b -> [t b]
forall (t :: * -> *) a. NavigatableTree t => t a -> [t a]
T.childAxis
descendantAxis :: (ArrowList a, NavigatableTree t) => a (t b) (t b)
descendantAxis :: forall (a :: * -> * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTree t) =>
a (t b) (t b)
descendantAxis = (t b -> [t b]) -> a (t b) (t b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL t b -> [t b]
forall (t :: * -> *) a. NavigatableTree t => t a -> [t a]
T.descendantAxis
descendantOrSelfAxis :: (ArrowList a, NavigatableTree t) => a (t b) (t b)
descendantOrSelfAxis :: forall (a :: * -> * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTree t) =>
a (t b) (t b)
descendantOrSelfAxis = (t b -> [t b]) -> a (t b) (t b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL t b -> [t b]
forall (t :: * -> *) a. NavigatableTree t => t a -> [t a]
T.descendantOrSelfAxis
descendantOrFollowingAxis :: (ArrowList a, NavigatableTree t) => a (t b) (t b)
descendantOrFollowingAxis :: forall (a :: * -> * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTree t) =>
a (t b) (t b)
descendantOrFollowingAxis = a (t b) (t b)
forall (a :: * -> * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTree t) =>
a (t b) (t b)
descendantAxis a (t b) (t b) -> a (t b) (t b) -> a (t b) (t b)
forall b c. a b c -> a b c -> a b c
forall (a :: * -> * -> *) b c.
ArrowPlus a =>
a b c -> a b c -> a b c
<+> a (t b) (t b)
forall (a :: * -> * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTree t) =>
a (t b) (t b)
followingAxis
revDescendantOrSelfAxis :: (ArrowList a, NavigatableTree t) => a (t b) (t b)
revDescendantOrSelfAxis :: forall (a :: * -> * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTree t) =>
a (t b) (t b)
revDescendantOrSelfAxis = (t b -> [t b]) -> a (t b) (t b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL t b -> [t b]
forall (t :: * -> *) a. NavigatableTree t => t a -> [t a]
T.revDescendantOrSelfAxis
followingSiblingAxis :: (ArrowList a, NavigatableTree t) => a (t b) (t b)
followingSiblingAxis :: forall (a :: * -> * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTree t) =>
a (t b) (t b)
followingSiblingAxis = (t b -> [t b]) -> a (t b) (t b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL t b -> [t b]
forall (t :: * -> *) a. NavigatableTree t => t a -> [t a]
T.followingSiblingAxis
precedingSiblingAxis :: (ArrowList a, NavigatableTree t) => a (t b) (t b)
precedingSiblingAxis :: forall (a :: * -> * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTree t) =>
a (t b) (t b)
precedingSiblingAxis = (t b -> [t b]) -> a (t b) (t b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL t b -> [t b]
forall (t :: * -> *) a. NavigatableTree t => t a -> [t a]
T.precedingSiblingAxis
selfAxis :: (ArrowList a, NavigatableTree t) => a (t b) (t b)
selfAxis :: forall (a :: * -> * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTree t) =>
a (t b) (t b)
selfAxis = (t b -> [t b]) -> a (t b) (t b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL t b -> [t b]
forall (t :: * -> *) a. NavigatableTree t => t a -> [t a]
T.selfAxis
followingAxis :: (ArrowList a, NavigatableTree t) => a (t b) (t b)
followingAxis :: forall (a :: * -> * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTree t) =>
a (t b) (t b)
followingAxis = (t b -> [t b]) -> a (t b) (t b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL t b -> [t b]
forall (t :: * -> *) a. NavigatableTree t => t a -> [t a]
T.followingAxis
precedingAxis :: (ArrowList a, NavigatableTree t) => a (t b) (t b)
precedingAxis :: forall (a :: * -> * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTree t) =>
a (t b) (t b)
precedingAxis = (t b -> [t b]) -> a (t b) (t b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL t b -> [t b]
forall (t :: * -> *) a. NavigatableTree t => t a -> [t a]
T.precedingAxis
moveToRoot :: (Arrow a, NavigatableTree t) => a (t b) (t b)
moveToRoot :: forall (a :: * -> * -> *) (t :: * -> *) b.
(Arrow a, NavigatableTree t) =>
a (t b) (t b)
moveToRoot = (t b -> t b) -> a (t b) (t b)
forall b c. (b -> c) -> a b c
forall (a :: * -> * -> *) b c. Arrow a => (b -> c) -> a b c
arr t b -> t b
forall (t :: * -> *) a. NavigatableTree t => t a -> t a
T.mvToRoot
isAtRoot :: (ArrowList a, NavigatableTree t) => a (t b) (t b)
isAtRoot :: forall (a :: * -> * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTree t) =>
a (t b) (t b)
isAtRoot = (t b -> Bool) -> a (t b) (t b)
forall b. (b -> Bool) -> a b b
forall (a :: * -> * -> *) b. ArrowList a => (b -> Bool) -> a b b
isA ([t b] -> Bool
forall a. [a] -> Bool
forall (t :: * -> *) a. Foldable t => t a -> Bool
null ([t b] -> Bool) -> (t b -> [t b]) -> t b -> Bool
forall b c a. (b -> c) -> (a -> b) -> a -> c
. t b -> [t b]
forall (t :: * -> *) a. NavigatableTree t => t a -> [t a]
T.ancestorAxis)
addNav :: ( ArrowList a
, NavigatableTreeToTree nt t
) =>
a (t b) (nt b)
addNav :: forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTreeToTree nt t) =>
a (t b) (nt b)
addNav = (t b -> nt b) -> a (t b) (nt b)
forall b c. (b -> c) -> a b c
forall (a :: * -> * -> *) b c. Arrow a => (b -> c) -> a b c
arr t b -> nt b
forall a. t a -> nt a
forall (nt :: * -> *) (t :: * -> *) a.
NavigatableTreeToTree nt t =>
t a -> nt a
T.fromTree
remNav :: ( ArrowList a
, NavigatableTreeToTree nt t
) =>
a (nt b) (t b)
remNav :: forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTreeToTree nt t) =>
a (nt b) (t b)
remNav = (nt b -> t b) -> a (nt b) (t b)
forall b c. (b -> c) -> a b c
forall (a :: * -> * -> *) b c. Arrow a => (b -> c) -> a b c
arr nt b -> t b
forall a. nt a -> t a
forall (nt :: * -> *) (t :: * -> *) a.
NavigatableTreeToTree nt t =>
nt a -> t a
T.toTree
withNav :: ( ArrowList a
, NavigatableTreeToTree nt t
) =>
a (nt b) (nt c) -> a (t b) (t c)
withNav :: forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b c.
(ArrowList a, NavigatableTreeToTree nt t) =>
a (nt b) (nt c) -> a (t b) (t c)
withNav a (nt b) (nt c)
f = a (t b) (nt b)
forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTreeToTree nt t) =>
a (t b) (nt b)
addNav a (t b) (nt b) -> a (nt b) (t c) -> a (t b) (t c)
forall {k} (cat :: k -> k -> *) (a :: k) (b :: k) (c :: k).
Category cat =>
cat a b -> cat b c -> cat a c
>>> a (nt b) (nt c)
f a (nt b) (nt c) -> a (nt c) (t c) -> a (nt b) (t c)
forall {k} (cat :: k -> k -> *) (a :: k) (b :: k) (c :: k).
Category cat =>
cat a b -> cat b c -> cat a c
>>> a (nt c) (t c)
forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTreeToTree nt t) =>
a (nt b) (t b)
remNav
withoutNav :: ( ArrowList a
, NavigatableTreeToTree nt t
, NavigatableTreeModify nt t
) =>
a (t b) (t b) -> a (nt b) (nt b)
withoutNav :: forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTreeToTree nt t,
NavigatableTreeModify nt t) =>
a (t b) (t b) -> a (nt b) (nt b)
withoutNav a (t b) (t b)
f = ( (a (nt b) (t b)
forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTreeToTree nt t) =>
a (nt b) (t b)
remNav a (nt b) (t b) -> a (t b) (t b) -> a (nt b) (t b)
forall {k} (cat :: k -> k -> *) (a :: k) (b :: k) (c :: k).
Category cat =>
cat a b -> cat b c -> cat a c
>>> a (t b) (t b)
f)
a (nt b) (t b) -> a (nt b) (nt b) -> a (nt b) (t b, nt b)
forall b c c'. a b c -> a b c' -> a b (c, c')
forall (a :: * -> * -> *) b c c'.
Arrow a =>
a b c -> a b c' -> a b (c, c')
&&&
a (nt b) (nt b)
forall b. a b b
forall (a :: * -> * -> *) b. ArrowList a => a b b
this
)
a (nt b) (t b, nt b) -> a (t b, nt b) (nt b) -> a (nt b) (nt b)
forall {k} (cat :: k -> k -> *) (a :: k) (b :: k) (c :: k).
Category cat =>
cat a b -> cat b c -> cat a c
>>> ((t b, nt b) -> nt b) -> a (t b, nt b) (nt b)
forall b c. (b -> c) -> a b c
forall (a :: * -> * -> *) b c. Arrow a => (b -> c) -> a b c
arr ((t b -> nt b -> nt b) -> (t b, nt b) -> nt b
forall a b c. (a -> b -> c) -> (a, b) -> c
uncurry t b -> nt b -> nt b
forall a. t a -> nt a -> nt a
forall (nt :: * -> *) (t :: * -> *) a.
NavigatableTreeModify nt t =>
t a -> nt a -> nt a
T.substThisTree)
filterAxis :: ( ArrowIf a
, NavigatableTreeToTree nt t
) =>
a (t b) c -> a (nt b) (nt b)
filterAxis :: forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b c.
(ArrowIf a, NavigatableTreeToTree nt t) =>
a (t b) c -> a (nt b) (nt b)
filterAxis a (t b) c
p = (a (nt b) (t b)
forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTreeToTree nt t) =>
a (nt b) (t b)
remNav a (nt b) (t b) -> a (t b) c -> a (nt b) c
forall {k} (cat :: k -> k -> *) (a :: k) (b :: k) (c :: k).
Category cat =>
cat a b -> cat b c -> cat a c
>>> a (t b) c
p) a (nt b) c -> a (nt b) (nt b) -> a (nt b) (nt b)
forall b c d. a b c -> a b d -> a b d
forall (a :: * -> * -> *) b c d.
ArrowIf a =>
a b c -> a b d -> a b d
`guards` a (nt b) (nt b)
forall b. a b b
forall (a :: * -> * -> *) b. ArrowList a => a b b
this
{-# INLINE filterAxis #-}
moveOn :: ( ArrowList a
, NavigatableTree t
) =>
a (t b) (t b) -> a (t b) (t b)
moveOn :: forall (a :: * -> * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTree t) =>
a (t b) (t b) -> a (t b) (t b)
moveOn a (t b) (t b)
axis = a (t b) (t b) -> a (t b) (t b)
forall b c. a b c -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => a b c -> a b c
single (a (t b) (t b) -> a (t b) (t b)) -> a (t b) (t b) -> a (t b) (t b)
forall a b. (a -> b) -> a -> b
$ a (t b) (t b)
axis
{-# INLINE moveOn #-}
changeThisTree :: ( ArrowList a
, ArrowIf a
, NavigatableTreeToTree nt t
, NavigatableTreeModify nt t
) =>
a (t b) (t b) -> a (nt b) (nt b)
changeThisTree :: forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, ArrowIf a, NavigatableTreeToTree nt t,
NavigatableTreeModify nt t) =>
a (t b) (t b) -> a (nt b) (nt b)
changeThisTree a (t b) (t b)
cf = a (t b) (t b) -> a (nt b) (nt b)
forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTreeToTree nt t,
NavigatableTreeModify nt t) =>
a (t b) (t b) -> a (nt b) (nt b)
withoutNav (a (t b) (t b) -> a (nt b) (nt b))
-> a (t b) (t b) -> a (nt b) (nt b)
forall a b. (a -> b) -> a -> b
$ a (t b) (t b) -> a (t b) (t b)
forall b c. a b c -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => a b c -> a b c
single a (t b) (t b)
cf a (t b) (t b) -> a (t b) (t b) -> a (t b) (t b)
forall b c. a b c -> a b c -> a b c
forall (a :: * -> * -> *) b c. ArrowIf a => a b c -> a b c -> a b c
`orElse` a (t b) (t b)
forall b. a b b
forall (a :: * -> * -> *) b. ArrowList a => a b b
this
substThisTree :: ( ArrowList a
, ArrowIf a
, NavigatableTreeToTree nt t
, NavigatableTreeModify nt t
) =>
t b -> a (nt b) (nt b)
substThisTree :: forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, ArrowIf a, NavigatableTreeToTree nt t,
NavigatableTreeModify nt t) =>
t b -> a (nt b) (nt b)
substThisTree t b
t = a (t b) (t b) -> a (nt b) (nt b)
forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, ArrowIf a, NavigatableTreeToTree nt t,
NavigatableTreeModify nt t) =>
a (t b) (t b) -> a (nt b) (nt b)
changeThisTree (t b -> a (t b) (t b)
forall c b. c -> a b c
forall (a :: * -> * -> *) c b. ArrowList a => c -> a b c
constA t b
t)
addToTheLeft :: ( ArrowList a
, NavigatableTreeToTree nt t
, NavigatableTreeModify nt t
) =>
a (t b) (t b) -> a (nt b) (nt b)
addToTheLeft :: forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTreeToTree nt t,
NavigatableTreeModify nt t) =>
a (t b) (t b) -> a (nt b) (nt b)
addToTheLeft = (Maybe (nt b) -> [t b] -> Maybe (nt b))
-> a (t b) (t b) -> a (nt b) (nt b)
forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTreeToTree nt t,
NavigatableTreeModify nt t) =>
(Maybe (nt b) -> [t b] -> Maybe (nt b))
-> a (t b) (t b) -> a (nt b) (nt b)
addToOneSide ((Maybe (nt b) -> [t b] -> Maybe (nt b))
-> a (t b) (t b) -> a (nt b) (nt b))
-> (Maybe (nt b) -> [t b] -> Maybe (nt b))
-> a (t b) (t b)
-> a (nt b) (nt b)
forall a b. (a -> b) -> a -> b
$
(Maybe (nt b) -> t b -> Maybe (nt b))
-> Maybe (nt b) -> [t b] -> Maybe (nt b)
forall b a. (b -> a -> b) -> b -> [a] -> b
forall (t :: * -> *) b a.
Foldable t =>
(b -> a -> b) -> b -> t a -> b
foldl (\ Maybe (nt b)
acc t b
t -> Maybe (nt b)
acc Maybe (nt b) -> (nt b -> Maybe (nt b)) -> Maybe (nt b)
forall a b. Maybe a -> (a -> Maybe b) -> Maybe b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= t b -> nt b -> Maybe (nt b)
forall a. t a -> nt a -> Maybe (nt a)
forall (nt :: * -> *) (t :: * -> *) a.
NavigatableTreeModify nt t =>
t a -> nt a -> Maybe (nt a)
T.addTreeLeft t b
t)
{-# INLINE addToTheLeft #-}
addToTheRight :: ( ArrowList a
, NavigatableTreeToTree nt t
, NavigatableTreeModify nt t
) =>
a (t b) (t b) -> a (nt b) (nt b)
addToTheRight :: forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTreeToTree nt t,
NavigatableTreeModify nt t) =>
a (t b) (t b) -> a (nt b) (nt b)
addToTheRight = (Maybe (nt b) -> [t b] -> Maybe (nt b))
-> a (t b) (t b) -> a (nt b) (nt b)
forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTreeToTree nt t,
NavigatableTreeModify nt t) =>
(Maybe (nt b) -> [t b] -> Maybe (nt b))
-> a (t b) (t b) -> a (nt b) (nt b)
addToOneSide ((Maybe (nt b) -> [t b] -> Maybe (nt b))
-> a (t b) (t b) -> a (nt b) (nt b))
-> (Maybe (nt b) -> [t b] -> Maybe (nt b))
-> a (t b) (t b)
-> a (nt b) (nt b)
forall a b. (a -> b) -> a -> b
$
(t b -> Maybe (nt b) -> Maybe (nt b))
-> Maybe (nt b) -> [t b] -> Maybe (nt b)
forall a b. (a -> b -> b) -> b -> [a] -> b
forall (t :: * -> *) a b.
Foldable t =>
(a -> b -> b) -> b -> t a -> b
foldr (\ t b
t Maybe (nt b)
acc -> Maybe (nt b)
acc Maybe (nt b) -> (nt b -> Maybe (nt b)) -> Maybe (nt b)
forall a b. Maybe a -> (a -> Maybe b) -> Maybe b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= t b -> nt b -> Maybe (nt b)
forall a. t a -> nt a -> Maybe (nt a)
forall (nt :: * -> *) (t :: * -> *) a.
NavigatableTreeModify nt t =>
t a -> nt a -> Maybe (nt a)
T.addTreeRight t b
t)
{-# INLINE addToTheRight #-}
addToOneSide :: ( ArrowList a
, NavigatableTreeToTree nt t
, NavigatableTreeModify nt t
) =>
( Maybe (nt b) -> [t b] -> Maybe (nt b) ) ->
a (t b) (t b) ->
a (nt b) (nt b)
addToOneSide :: forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTreeToTree nt t,
NavigatableTreeModify nt t) =>
(Maybe (nt b) -> [t b] -> Maybe (nt b))
-> a (t b) (t b) -> a (nt b) (nt b)
addToOneSide Maybe (nt b) -> [t b] -> Maybe (nt b)
side a (t b) (t b)
f = ( ( a (nt b) (t b)
forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTreeToTree nt t) =>
a (nt b) (t b)
remNav a (nt b) (t b) -> a (t b) [t b] -> a (nt b) [t b]
forall {k} (cat :: k -> k -> *) (a :: k) (b :: k) (c :: k).
Category cat =>
cat a b -> cat b c -> cat a c
>>> a (t b) (t b) -> a (t b) [t b]
forall b c. a b c -> a b [c]
forall (a :: * -> * -> *) b c. ArrowList a => a b c -> a b [c]
listA a (t b) (t b)
f )
a (nt b) [t b] -> a (nt b) (nt b) -> a (nt b) ([t b], nt b)
forall b c c'. a b c -> a b c' -> a b (c, c')
forall (a :: * -> * -> *) b c c'.
Arrow a =>
a b c -> a b c' -> a b (c, c')
&&&
a (nt b) (nt b)
forall b. a b b
forall (a :: * -> * -> *) b. ArrowList a => a b b
this
)
a (nt b) ([t b], nt b) -> a ([t b], nt b) (nt b) -> a (nt b) (nt b)
forall {k} (cat :: k -> k -> *) (a :: k) (b :: k) (c :: k).
Category cat =>
cat a b -> cat b c -> cat a c
>>>
(([t b], nt b) -> [nt b]) -> a ([t b], nt b) (nt b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL ( ([t b] -> nt b -> Maybe (nt b)) -> ([t b], nt b) -> Maybe (nt b)
forall a b c. (a -> b -> c) -> (a, b) -> c
uncurry (\ [t b]
ts nt b
nt -> Maybe (nt b) -> [t b] -> Maybe (nt b)
side (nt b -> Maybe (nt b)
forall a. a -> Maybe a
Just nt b
nt) [t b]
ts)
(([t b], nt b) -> Maybe (nt b))
-> (Maybe (nt b) -> [nt b]) -> ([t b], nt b) -> [nt b]
forall {k} (cat :: k -> k -> *) (a :: k) (b :: k) (c :: k).
Category cat =>
cat a b -> cat b c -> cat a c
>>>
Maybe (nt b) -> [nt b]
forall a. Maybe a -> [a]
maybeToList
)
dropFromTheLeft :: ( ArrowList a
, NavigatableTreeModify nt t
) =>
a (nt b) (nt b)
dropFromTheLeft :: forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTreeModify nt t) =>
a (nt b) (nt b)
dropFromTheLeft = (nt b -> [nt b]) -> a (nt b) (nt b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL ((nt b -> [nt b]) -> a (nt b) (nt b))
-> (nt b -> [nt b]) -> a (nt b) (nt b)
forall a b. (a -> b) -> a -> b
$ nt b -> Maybe (nt b)
forall a. nt a -> Maybe (nt a)
forall (nt :: * -> *) (t :: * -> *) a.
NavigatableTreeModify nt t =>
nt a -> Maybe (nt a)
T.dropTreeLeft (nt b -> Maybe (nt b))
-> (Maybe (nt b) -> [nt b]) -> nt b -> [nt b]
forall {k} (cat :: k -> k -> *) (a :: k) (b :: k) (c :: k).
Category cat =>
cat a b -> cat b c -> cat a c
>>> Maybe (nt b) -> [nt b]
forall a. Maybe a -> [a]
maybeToList
{-# INLINE dropFromTheLeft #-}
dropFromTheRight :: ( ArrowList a
, NavigatableTreeModify nt t
) =>
a (nt b) (nt b)
dropFromTheRight :: forall (a :: * -> * -> *) (nt :: * -> *) (t :: * -> *) b.
(ArrowList a, NavigatableTreeModify nt t) =>
a (nt b) (nt b)
dropFromTheRight = (nt b -> [nt b]) -> a (nt b) (nt b)
forall b c. (b -> [c]) -> a b c
forall (a :: * -> * -> *) b c. ArrowList a => (b -> [c]) -> a b c
arrL ((nt b -> [nt b]) -> a (nt b) (nt b))
-> (nt b -> [nt b]) -> a (nt b) (nt b)
forall a b. (a -> b) -> a -> b
$ nt b -> Maybe (nt b)
forall a. nt a -> Maybe (nt a)
forall (nt :: * -> *) (t :: * -> *) a.
NavigatableTreeModify nt t =>
nt a -> Maybe (nt a)
T.dropTreeRight (nt b -> Maybe (nt b))
-> (Maybe (nt b) -> [nt b]) -> nt b -> [nt b]
forall {k} (cat :: k -> k -> *) (a :: k) (b :: k) (c :: k).
Category cat =>
cat a b -> cat b c -> cat a c
>>> Maybe (nt b) -> [nt b]
forall a. Maybe a -> [a]
maybeToList
{-# INLINE dropFromTheRight #-}