Safe Haskell | Trustworthy |
---|---|
Language | Haskell2010 |
Unstable implementation details
Synopsis
- class TrieKey k where
- type TrieRep k :: Type -> Type
- trieEmpty :: Trie k a
- trieNull :: Trie k a -> Bool
- trieLookup :: k -> Trie k a -> Maybe a
- trieInsert :: k -> a -> Trie k a -> Trie k a
- trieDelete :: k -> Trie k a -> Trie k a
- trieAlter :: k -> (Maybe a -> Maybe a) -> Trie k a -> Trie k a
- trieSingleton :: k -> a -> Trie k a
- trieMap :: (a -> b) -> Trie k a -> Trie k b
- trieTraverse :: Applicative f => (a -> f b) -> Trie k a -> f (Trie k b)
- trieMapMaybeWithKey :: (k -> a -> Maybe b) -> Trie k a -> Trie k b
- trieFoldWithKey :: (k -> a -> r -> r) -> r -> Trie k a -> r
- trieTraverseWithKey :: Applicative f => (k -> a -> f b) -> Trie k a -> f (Trie k b)
- trieTraverseMaybeWithKey :: Applicative f => (k -> a -> f (Maybe b)) -> Trie k a -> f (Trie k b)
- trieMergeWithKey :: (k -> a -> b -> Maybe c) -> (Trie k a -> Trie k c) -> (Trie k b -> Trie k c) -> Trie k a -> Trie k b -> Trie k c
- class TrieKey k => ShowTrieKey k where
- trieShowsPrec :: Show a => Int -> Trie k a -> ShowS
- newtype Trie k a = MkTrie (TrieRep k a)
- newtype OrdKey k = OrdKey {
- getOrdKey :: k
- toList :: TrieKey k => Trie k a -> [(k, a)]
- genericTrieNull :: TrieRep k ~ TrieRepDefault k => Trie k a -> Bool
- genericTrieMap :: (GTrieKey (Rep k), TrieRep k ~ TrieRepDefault k) => (a -> b) -> Trie k a -> Trie k b
- genericTrieTraverse :: (GTrieKey (Rep k), TrieRep k ~ TrieRepDefault k, Applicative f) => (a -> f b) -> Trie k a -> f (Trie k b)
- genericTrieShowsPrec :: (Show a, GTrieKeyShow (Rep k), TrieRep k ~ TrieRepDefault k) => Int -> Trie k a -> ShowS
- genericInsert :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => k -> a -> Trie k a -> Trie k a
- genericLookup :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => k -> Trie k a -> Maybe a
- genericDelete :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => k -> Trie k a -> Trie k a
- genericAlter :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => k -> (Maybe a -> Maybe a) -> Trie k a -> Trie k a
- genericMapMaybeWithKey :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => (k -> a -> Maybe b) -> Trie k a -> Trie k b
- genericSingleton :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => k -> a -> Trie k a
- genericEmpty :: TrieRep k ~ TrieRepDefault k => Trie k a
- genericFoldWithKey :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => (k -> a -> r -> r) -> r -> Trie k a -> r
- genericTraverseWithKey :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k, Applicative f) => (k -> a -> f b) -> Trie k a -> f (Trie k b)
- genericTraverseMaybeWithKey :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k, Applicative f) => (k -> a -> f (Maybe b)) -> Trie k a -> f (Trie k b)
- data TrieRepDefault k a
- class GTrieKey f where
- gtrieLookup :: f p -> GTrie f a -> Maybe a
- gtrieInsert :: f p -> a -> GTrie f a -> GTrie f a
- gtrieSingleton :: f p -> a -> GTrie f a
- gtrieDelete :: f p -> GTrie f a -> Maybe (GTrie f a)
- gtrieAlter :: f p -> (Maybe a -> Maybe a) -> GTrie f a -> Maybe (GTrie f a)
- gtrieMap :: (a -> b) -> GTrie f a -> GTrie f b
- gtrieTraverse :: Applicative m => (a -> m b) -> GTrie f a -> m (GTrie f b)
- gmapMaybeWithKey :: (f p -> a -> Maybe b) -> GTrie f a -> Maybe (GTrie f b)
- gfoldWithKey :: (f p -> a -> r -> r) -> r -> GTrie f a -> r
- gtraverseWithKey :: Applicative m => (f p -> a -> m b) -> GTrie f a -> m (GTrie f b)
- gtraverseMaybeWithKey :: Applicative m => (f p -> a -> m (Maybe b)) -> GTrie f a -> m (Maybe (GTrie f b))
- gmergeWithKey :: (f p -> a -> b -> Maybe c) -> (GTrie f a -> Maybe (GTrie f c)) -> (GTrie f b -> Maybe (GTrie f c)) -> GTrie f a -> GTrie f b -> Maybe (GTrie f c)
- data family GTrie f a
Documentation
class TrieKey k where Source #
Types that may be used as the key of a Trie
.
For data
declarations, the instance can be automatically derived from
a Generic
instance.
Nothing
type TrieRep k :: Type -> Type Source #
Type of the representation of tries for this key.
type TrieRep k = TrieRepDefault k
trieEmpty :: Trie k a Source #
Construct an empty trie
trieNull :: Trie k a -> Bool Source #
Test for an empty trie
trieLookup :: k -> Trie k a -> Maybe a Source #
Lookup element from trie
default trieLookup :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => k -> Trie k a -> Maybe a Source #
trieInsert :: k -> a -> Trie k a -> Trie k a Source #
Insert element into trie
default trieInsert :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => k -> a -> Trie k a -> Trie k a Source #
trieDelete :: k -> Trie k a -> Trie k a Source #
Delete element from trie
default trieDelete :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => k -> Trie k a -> Trie k a Source #
trieAlter :: k -> (Maybe a -> Maybe a) -> Trie k a -> Trie k a Source #
Insert, modify, or remove an element in a trie
default trieAlter :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => k -> (Maybe a -> Maybe a) -> Trie k a -> Trie k a Source #
trieSingleton :: k -> a -> Trie k a Source #
Construct a trie holding a single value
default trieSingleton :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => k -> a -> Trie k a Source #
trieMap :: (a -> b) -> Trie k a -> Trie k b Source #
Apply a function to all values stored in a trie
default trieMap :: (GTrieKey (Rep k), TrieRep k ~ TrieRepDefault k) => (a -> b) -> Trie k a -> Trie k b Source #
trieTraverse :: Applicative f => (a -> f b) -> Trie k a -> f (Trie k b) Source #
Traverse the values stored in a trie
default trieTraverse :: (GTrieKey (Rep k), TrieRep k ~ TrieRepDefault k, Applicative f) => (a -> f b) -> Trie k a -> f (Trie k b) Source #
trieMapMaybeWithKey :: (k -> a -> Maybe b) -> Trie k a -> Trie k b Source #
Apply a function to the values of a Trie
and keep the elements
of the trie that result in a Just
value.
default trieMapMaybeWithKey :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => (k -> a -> Maybe b) -> Trie k a -> Trie k b Source #
trieFoldWithKey :: (k -> a -> r -> r) -> r -> Trie k a -> r Source #
Fold a trie with a function of both key and value.
default trieFoldWithKey :: (GTrieKey (Rep k), TrieRep k ~ TrieRepDefault k, Generic k) => (k -> a -> r -> r) -> r -> Trie k a -> r Source #
trieTraverseWithKey :: Applicative f => (k -> a -> f b) -> Trie k a -> f (Trie k b) Source #
Traverse a trie with a function of both key and value.
default trieTraverseWithKey :: (GTrieKey (Rep k), TrieRep k ~ TrieRepDefault k, Generic k, Applicative f) => (k -> a -> f b) -> Trie k a -> f (Trie k b) Source #
trieTraverseMaybeWithKey :: Applicative f => (k -> a -> f (Maybe b)) -> Trie k a -> f (Trie k b) Source #
Traverse a trie with a function of both key and value, and keep the elements
of the trie that result in a Just
value.
default trieTraverseMaybeWithKey :: (GTrieKey (Rep k), TrieRep k ~ TrieRepDefault k, Generic k, Applicative f) => (k -> a -> f (Maybe b)) -> Trie k a -> f (Trie k b) Source #
trieMergeWithKey :: (k -> a -> b -> Maybe c) -> (Trie k a -> Trie k c) -> (Trie k b -> Trie k c) -> Trie k a -> Trie k b -> Trie k c Source #
Instances
class TrieKey k => ShowTrieKey k where Source #
Nothing
trieShowsPrec :: Show a => Int -> Trie k a -> ShowS Source #
Show a representation of the internal structure of a trie
default trieShowsPrec :: (Show a, GTrieKeyShow (Rep k), TrieRep k ~ TrieRepDefault k) => Int -> Trie k a -> ShowS Source #
Instances
A map from keys of type k
, to values of type a
.
Instances
TrieKey k => Foldable (Trie k) Source # | |
Defined in Data.GenericTrie.Internal fold :: Monoid m => Trie k m -> m # foldMap :: Monoid m => (a -> m) -> Trie k a -> m # foldMap' :: Monoid m => (a -> m) -> Trie k a -> m # foldr :: (a -> b -> b) -> b -> Trie k a -> b # foldr' :: (a -> b -> b) -> b -> Trie k a -> b # foldl :: (b -> a -> b) -> b -> Trie k a -> b # foldl' :: (b -> a -> b) -> b -> Trie k a -> b # foldr1 :: (a -> a -> a) -> Trie k a -> a # foldl1 :: (a -> a -> a) -> Trie k a -> a # elem :: Eq a => a -> Trie k a -> Bool # maximum :: Ord a => Trie k a -> a # minimum :: Ord a => Trie k a -> a # | |
TrieKey k => Traversable (Trie k) Source # | |
TrieKey k => Functor (Trie k) Source # | |
(TrieKey k, Show k, Show a) => Show (Trie k a) Source # | |
Tries indexed by OrdKey
will be represented as an ordinary Map
and the keys will be compared based on the Ord
instance for k
.
Instances
Generic derivation implementation
genericTrieNull :: TrieRep k ~ TrieRepDefault k => Trie k a -> Bool Source #
Generic implementation of trieNull
. This is the default implementation.
genericTrieMap :: (GTrieKey (Rep k), TrieRep k ~ TrieRepDefault k) => (a -> b) -> Trie k a -> Trie k b Source #
Generic implementation of trieMap
. This is the default implementation.
genericTrieTraverse :: (GTrieKey (Rep k), TrieRep k ~ TrieRepDefault k, Applicative f) => (a -> f b) -> Trie k a -> f (Trie k b) Source #
Generic implementation of trieTraverse
. This is the default implementation.
genericTrieShowsPrec :: (Show a, GTrieKeyShow (Rep k), TrieRep k ~ TrieRepDefault k) => Int -> Trie k a -> ShowS Source #
Generic implementation of trieShowsPrec
. This is the default implementation.
genericInsert :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => k -> a -> Trie k a -> Trie k a Source #
Generic implementation of insert
. This is the default implementation.
genericLookup :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => k -> Trie k a -> Maybe a Source #
Generic implementation of lookup
. This is the default implementation.
genericDelete :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => k -> Trie k a -> Trie k a Source #
Generic implementation of delete
. This is the default implementation.
genericAlter :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => k -> (Maybe a -> Maybe a) -> Trie k a -> Trie k a Source #
Generic implementation of alter
. This is the default implementation.
genericMapMaybeWithKey :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => (k -> a -> Maybe b) -> Trie k a -> Trie k b Source #
Generic implementation of mapMaybe
. This is the default implementation.
genericSingleton :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => k -> a -> Trie k a Source #
Generic implementation of singleton
. This is the default implementation.
genericEmpty :: TrieRep k ~ TrieRepDefault k => Trie k a Source #
Generic implementation of empty
. This is the default implementation.
genericFoldWithKey :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k) => (k -> a -> r -> r) -> r -> Trie k a -> r Source #
Generic implementation of foldWithKey
. This is the default implementation.
genericTraverseWithKey :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k, Applicative f) => (k -> a -> f b) -> Trie k a -> f (Trie k b) Source #
Generic implementation of traverseWithKey
. This is the default implementation.
genericTraverseMaybeWithKey :: (GTrieKey (Rep k), Generic k, TrieRep k ~ TrieRepDefault k, Applicative f) => (k -> a -> f (Maybe b)) -> Trie k a -> f (Trie k b) Source #
Generic implementation of traverseMaybeWithKey
. This is the default implementation.
data TrieRepDefault k a Source #
class GTrieKey f where Source #
TrieKey operations on Generic representations used to provide the default implementations of tries.
gtrieLookup :: f p -> GTrie f a -> Maybe a Source #
gtrieInsert :: f p -> a -> GTrie f a -> GTrie f a Source #
gtrieSingleton :: f p -> a -> GTrie f a Source #
gtrieDelete :: f p -> GTrie f a -> Maybe (GTrie f a) Source #
gtrieAlter :: f p -> (Maybe a -> Maybe a) -> GTrie f a -> Maybe (GTrie f a) Source #
gtrieMap :: (a -> b) -> GTrie f a -> GTrie f b Source #
gtrieTraverse :: Applicative m => (a -> m b) -> GTrie f a -> m (GTrie f b) Source #
gmapMaybeWithKey :: (f p -> a -> Maybe b) -> GTrie f a -> Maybe (GTrie f b) Source #
gfoldWithKey :: (f p -> a -> r -> r) -> r -> GTrie f a -> r Source #
gtraverseWithKey :: Applicative m => (f p -> a -> m b) -> GTrie f a -> m (GTrie f b) Source #
gtraverseMaybeWithKey :: Applicative m => (f p -> a -> m (Maybe b)) -> GTrie f a -> m (Maybe (GTrie f b)) Source #
gmergeWithKey :: (f p -> a -> b -> Maybe c) -> (GTrie f a -> Maybe (GTrie f c)) -> (GTrie f b -> Maybe (GTrie f c)) -> GTrie f a -> GTrie f b -> Maybe (GTrie f c) Source #
Instances
GTrieKey (U1 :: Type -> Type) Source # | Tries of constructors without fields are represented by a single value. |
Defined in Data.GenericTrie.Internal gtrieLookup :: U1 p -> GTrie U1 a -> Maybe a Source # gtrieInsert :: U1 p -> a -> GTrie U1 a -> GTrie U1 a Source # gtrieSingleton :: U1 p -> a -> GTrie U1 a Source # gtrieDelete :: U1 p -> GTrie U1 a -> Maybe (GTrie U1 a) Source # gtrieAlter :: U1 p -> (Maybe a -> Maybe a) -> GTrie U1 a -> Maybe (GTrie U1 a) Source # gtrieMap :: (a -> b) -> GTrie U1 a -> GTrie U1 b Source # gtrieTraverse :: Applicative m => (a -> m b) -> GTrie U1 a -> m (GTrie U1 b) Source # gmapMaybeWithKey :: (U1 p -> a -> Maybe b) -> GTrie U1 a -> Maybe (GTrie U1 b) Source # gfoldWithKey :: (U1 p -> a -> r -> r) -> r -> GTrie U1 a -> r Source # gtraverseWithKey :: Applicative m => (U1 p -> a -> m b) -> GTrie U1 a -> m (GTrie U1 b) Source # gtraverseMaybeWithKey :: Applicative m => (U1 p -> a -> m (Maybe b)) -> GTrie U1 a -> m (Maybe (GTrie U1 b)) Source # gmergeWithKey :: (U1 p -> a -> b -> Maybe c) -> (GTrie U1 a -> Maybe (GTrie U1 c)) -> (GTrie U1 b -> Maybe (GTrie U1 c)) -> GTrie U1 a -> GTrie U1 b -> Maybe (GTrie U1 c) Source # | |
GTrieKey (V1 :: Type -> Type) Source # | Tries of types without constructors are represented by an empty type. |
Defined in Data.GenericTrie.Internal gtrieLookup :: V1 p -> GTrie V1 a -> Maybe a Source # gtrieInsert :: V1 p -> a -> GTrie V1 a -> GTrie V1 a Source # gtrieSingleton :: V1 p -> a -> GTrie V1 a Source # gtrieDelete :: V1 p -> GTrie V1 a -> Maybe (GTrie V1 a) Source # gtrieAlter :: V1 p -> (Maybe a -> Maybe a) -> GTrie V1 a -> Maybe (GTrie V1 a) Source # gtrieMap :: (a -> b) -> GTrie V1 a -> GTrie V1 b Source # gtrieTraverse :: Applicative m => (a -> m b) -> GTrie V1 a -> m (GTrie V1 b) Source # gmapMaybeWithKey :: (V1 p -> a -> Maybe b) -> GTrie V1 a -> Maybe (GTrie V1 b) Source # gfoldWithKey :: (V1 p -> a -> r -> r) -> r -> GTrie V1 a -> r Source # gtraverseWithKey :: Applicative m => (V1 p -> a -> m b) -> GTrie V1 a -> m (GTrie V1 b) Source # gtraverseMaybeWithKey :: Applicative m => (V1 p -> a -> m (Maybe b)) -> GTrie V1 a -> m (Maybe (GTrie V1 b)) Source # gmergeWithKey :: (V1 p -> a -> b -> Maybe c) -> (GTrie V1 a -> Maybe (GTrie V1 c)) -> (GTrie V1 b -> Maybe (GTrie V1 c)) -> GTrie V1 a -> GTrie V1 b -> Maybe (GTrie V1 c) Source # | |
(GTrieKey f, GTrieKey g) => GTrieKey (f :*: g) Source # | Generic products are represented by tries of tries. |
Defined in Data.GenericTrie.Internal gtrieLookup :: (f :*: g) p -> GTrie (f :*: g) a -> Maybe a Source # gtrieInsert :: (f :*: g) p -> a -> GTrie (f :*: g) a -> GTrie (f :*: g) a Source # gtrieSingleton :: (f :*: g) p -> a -> GTrie (f :*: g) a Source # gtrieDelete :: (f :*: g) p -> GTrie (f :*: g) a -> Maybe (GTrie (f :*: g) a) Source # gtrieAlter :: (f :*: g) p -> (Maybe a -> Maybe a) -> GTrie (f :*: g) a -> Maybe (GTrie (f :*: g) a) Source # gtrieMap :: (a -> b) -> GTrie (f :*: g) a -> GTrie (f :*: g) b Source # gtrieTraverse :: Applicative m => (a -> m b) -> GTrie (f :*: g) a -> m (GTrie (f :*: g) b) Source # gmapMaybeWithKey :: ((f :*: g) p -> a -> Maybe b) -> GTrie (f :*: g) a -> Maybe (GTrie (f :*: g) b) Source # gfoldWithKey :: ((f :*: g) p -> a -> r -> r) -> r -> GTrie (f :*: g) a -> r Source # gtraverseWithKey :: Applicative m => ((f :*: g) p -> a -> m b) -> GTrie (f :*: g) a -> m (GTrie (f :*: g) b) Source # gtraverseMaybeWithKey :: Applicative m => ((f :*: g) p -> a -> m (Maybe b)) -> GTrie (f :*: g) a -> m (Maybe (GTrie (f :*: g) b)) Source # gmergeWithKey :: ((f :*: g) p -> a -> b -> Maybe c) -> (GTrie (f :*: g) a -> Maybe (GTrie (f :*: g) c)) -> (GTrie (f :*: g) b -> Maybe (GTrie (f :*: g) c)) -> GTrie (f :*: g) a -> GTrie (f :*: g) b -> Maybe (GTrie (f :*: g) c) Source # | |
(GTrieKey f, GTrieKey g) => GTrieKey (f :+: g) Source # | Generic sums are represented by up to a pair of sub-tries. |
Defined in Data.GenericTrie.Internal gtrieLookup :: (f :+: g) p -> GTrie (f :+: g) a -> Maybe a Source # gtrieInsert :: (f :+: g) p -> a -> GTrie (f :+: g) a -> GTrie (f :+: g) a Source # gtrieSingleton :: (f :+: g) p -> a -> GTrie (f :+: g) a Source # gtrieDelete :: (f :+: g) p -> GTrie (f :+: g) a -> Maybe (GTrie (f :+: g) a) Source # gtrieAlter :: (f :+: g) p -> (Maybe a -> Maybe a) -> GTrie (f :+: g) a -> Maybe (GTrie (f :+: g) a) Source # gtrieMap :: (a -> b) -> GTrie (f :+: g) a -> GTrie (f :+: g) b Source # gtrieTraverse :: Applicative m => (a -> m b) -> GTrie (f :+: g) a -> m (GTrie (f :+: g) b) Source # gmapMaybeWithKey :: ((f :+: g) p -> a -> Maybe b) -> GTrie (f :+: g) a -> Maybe (GTrie (f :+: g) b) Source # gfoldWithKey :: ((f :+: g) p -> a -> r -> r) -> r -> GTrie (f :+: g) a -> r Source # gtraverseWithKey :: Applicative m => ((f :+: g) p -> a -> m b) -> GTrie (f :+: g) a -> m (GTrie (f :+: g) b) Source # gtraverseMaybeWithKey :: Applicative m => ((f :+: g) p -> a -> m (Maybe b)) -> GTrie (f :+: g) a -> m (Maybe (GTrie (f :+: g) b)) Source # gmergeWithKey :: ((f :+: g) p -> a -> b -> Maybe c) -> (GTrie (f :+: g) a -> Maybe (GTrie (f :+: g) c)) -> (GTrie (f :+: g) b -> Maybe (GTrie (f :+: g) c)) -> GTrie (f :+: g) a -> GTrie (f :+: g) b -> Maybe (GTrie (f :+: g) c) Source # | |
TrieKey k => GTrieKey (K1 i k :: Type -> Type) Source # | Generic fields are represented by tries of the field type. |
Defined in Data.GenericTrie.Internal gtrieLookup :: K1 i k p -> GTrie (K1 i k) a -> Maybe a Source # gtrieInsert :: K1 i k p -> a -> GTrie (K1 i k) a -> GTrie (K1 i k) a Source # gtrieSingleton :: K1 i k p -> a -> GTrie (K1 i k) a Source # gtrieDelete :: K1 i k p -> GTrie (K1 i k) a -> Maybe (GTrie (K1 i k) a) Source # gtrieAlter :: K1 i k p -> (Maybe a -> Maybe a) -> GTrie (K1 i k) a -> Maybe (GTrie (K1 i k) a) Source # gtrieMap :: (a -> b) -> GTrie (K1 i k) a -> GTrie (K1 i k) b Source # gtrieTraverse :: Applicative m => (a -> m b) -> GTrie (K1 i k) a -> m (GTrie (K1 i k) b) Source # gmapMaybeWithKey :: (K1 i k p -> a -> Maybe b) -> GTrie (K1 i k) a -> Maybe (GTrie (K1 i k) b) Source # gfoldWithKey :: (K1 i k p -> a -> r -> r) -> r -> GTrie (K1 i k) a -> r Source # gtraverseWithKey :: Applicative m => (K1 i k p -> a -> m b) -> GTrie (K1 i k) a -> m (GTrie (K1 i k) b) Source # gtraverseMaybeWithKey :: Applicative m => (K1 i k p -> a -> m (Maybe b)) -> GTrie (K1 i k) a -> m (Maybe (GTrie (K1 i k) b)) Source # gmergeWithKey :: (K1 i k p -> a -> b -> Maybe c) -> (GTrie (K1 i k) a -> Maybe (GTrie (K1 i k) c)) -> (GTrie (K1 i k) b -> Maybe (GTrie (K1 i k) c)) -> GTrie (K1 i k) a -> GTrie (K1 i k) b -> Maybe (GTrie (K1 i k) c) Source # | |
GTrieKey f => GTrieKey (M1 i c f) Source # | Generic metadata is skipped in trie representation and operations. |
Defined in Data.GenericTrie.Internal gtrieLookup :: M1 i c f p -> GTrie (M1 i c f) a -> Maybe a Source # gtrieInsert :: M1 i c f p -> a -> GTrie (M1 i c f) a -> GTrie (M1 i c f) a Source # gtrieSingleton :: M1 i c f p -> a -> GTrie (M1 i c f) a Source # gtrieDelete :: M1 i c f p -> GTrie (M1 i c f) a -> Maybe (GTrie (M1 i c f) a) Source # gtrieAlter :: M1 i c f p -> (Maybe a -> Maybe a) -> GTrie (M1 i c f) a -> Maybe (GTrie (M1 i c f) a) Source # gtrieMap :: (a -> b) -> GTrie (M1 i c f) a -> GTrie (M1 i c f) b Source # gtrieTraverse :: Applicative m => (a -> m b) -> GTrie (M1 i c f) a -> m (GTrie (M1 i c f) b) Source # gmapMaybeWithKey :: (M1 i c f p -> a -> Maybe b) -> GTrie (M1 i c f) a -> Maybe (GTrie (M1 i c f) b) Source # gfoldWithKey :: (M1 i c f p -> a -> r -> r) -> r -> GTrie (M1 i c f) a -> r Source # gtraverseWithKey :: Applicative m => (M1 i c f p -> a -> m b) -> GTrie (M1 i c f) a -> m (GTrie (M1 i c f) b) Source # gtraverseMaybeWithKey :: Applicative m => (M1 i c f p -> a -> m (Maybe b)) -> GTrie (M1 i c f) a -> m (Maybe (GTrie (M1 i c f) b)) Source # gmergeWithKey :: (M1 i c f p -> a -> b -> Maybe c0) -> (GTrie (M1 i c f) a -> Maybe (GTrie (M1 i c f) c0)) -> (GTrie (M1 i c f) b -> Maybe (GTrie (M1 i c f) c0)) -> GTrie (M1 i c f) a -> GTrie (M1 i c f) b -> Maybe (GTrie (M1 i c f) c0) Source # |
data family GTrie f a Source #
Mapping of generic representation of keys to trie structures.
Instances
GTrieKey f => Functor (GTrie f) Source # | |
(Show a, GTrieKeyShow f) => Show (GTrie f a) Source # | |
newtype GTrie (U1 :: Type -> Type) a Source # | |
data GTrie (V1 :: Type -> Type) a Source # | |
Defined in Data.GenericTrie.Internal | |
newtype GTrie (f :*: g) a Source # | |
data GTrie (f :+: g) a Source # | |
newtype GTrie (K1 i k :: Type -> Type) a Source # | |
newtype GTrie (M1 i c f) a Source # | |
Defined in Data.GenericTrie.Internal |