Copyright | (c) 2021 Xy Ren |
---|---|
License | BSD3 |
Maintainer | xy.r@outlook.com |
Stability | unstable |
Portability | non-portable (GHC only) |
Safe Haskell | None |
Language | Haskell2010 |
This module defines an immutable extensible record type, similar to vinyl
and data-diverse
. However this
implementation focuses on fast reads, hence has very different performance characteristics from other libraries:
- Lookup: Amortized \( O(1) \).
- Update: \( O(n) \).
- Shrink: \( O(1) \).
- Append: \( O(n) \).
This is an internal module and its API may change even between minor versions. Therefore you should be extra careful if you're to depend on this module.
Synopsis
- newtype HandlerPtr (e :: Effect) = HandlerPtr {
- unHandlerPtr :: Int
- data Rec (es :: [Effect])
- type family xs ++ ys where ...
- empty :: Rec '[]
- cons :: HandlerPtr e -> Rec es -> Rec (e ': es)
- concat :: Rec es -> Rec es' -> Rec (es ++ es')
- class KnownList (es :: [Effect])
- head :: Rec (e ': es) -> HandlerPtr e
- take :: forall es es'. KnownList es => Rec (es ++ es') -> Rec es
- tail :: Rec (e ': es) -> Rec es
- drop :: forall es es'. KnownList es => Rec (es ++ es') -> Rec es'
- class (e :: Effect) :> (es :: [Effect])
- class KnownList es => Subset (es :: [Effect]) (es' :: [Effect])
- index :: forall e es. e :> es => Rec es -> HandlerPtr e
- pick :: forall es es'. Subset es es' => Rec es' -> Rec es
- update :: forall e es. e :> es => HandlerPtr e -> Rec es -> Rec es
Documentation
newtype HandlerPtr (e :: Effect) Source #
A pointer to an effect handler.
data Rec (es :: [Effect]) Source #
Extensible record type supporting efficient \( O(1) \) reads. The underlying implementation is PrimArray
slices.
Construction
cons :: HandlerPtr e -> Rec es -> Rec (e ': es) Source #
Prepend one entry to the record. \( O(n) \).
Deconstruction
class KnownList (es :: [Effect]) Source #
means the list KnownList
eses
is concrete, i.e. is of the form '[a1, a2, ..., an]
instead of a type
variable.
head :: Rec (e ': es) -> HandlerPtr e Source #
Get the head of the record. \( O(1) \).
take :: forall es es'. KnownList es => Rec (es ++ es') -> Rec es Source #
Take elements from the top of the record. \( O(m) \).
drop :: forall es es'. KnownList es => Rec (es ++ es') -> Rec es' Source #
Slice off several entries from the top of the record. \( O(1) \).
Retrieval and updating
class (e :: Effect) :> (es :: [Effect]) infix 0 Source #
e
means the effect :>
ese
is present in the effect stack es
, and therefore can be send
ed in an
computation.Eff
es
Instances
(TypeError (ElemNotFound e) :: Constraint) => e :> ('[] :: [Effect]) Source # | |
Defined in Cleff.Internal.Rec reifyIndex :: Int | |
e :> es => e :> (e' ': es) Source # | |
Defined in Cleff.Internal.Rec reifyIndex :: Int | |
e :> (e ': es) Source # | The element closer to the head takes priority. |
Defined in Cleff.Internal.Rec reifyIndex :: Int |
class KnownList es => Subset (es :: [Effect]) (es' :: [Effect]) Source #
es
is a subset of es'
, i.e. all elements of es
are in es'
.
Instances
Subset ('[] :: [Effect]) es Source # | |
Defined in Cleff.Internal.Rec reifyIndices :: [Int] | |
(Subset es es', e :> es') => Subset (e ': es) es' Source # | |
Defined in Cleff.Internal.Rec reifyIndices :: [Int] |
index :: forall e es. e :> es => Rec es -> HandlerPtr e Source #
Get an element in the record. Amortized \( O(1) \).