Safe Haskell | Safe-Inferred |
---|---|
Language | Haskell2010 |
- data HSet elems where
- class (i ~ Index e els) => HGet els e i where
- type HGetable els e = HGet els e (Index e els)
- hask :: (MonadReader (HSet els) m, HGetable els e) => m e
- class (eq ~ TEq els els2) => SubHSet els els2 eq where
- type SubHSetable els1 els2 eq = (SubHSet els1 els2 eq, eq ~ TEq els1 els2)
- hdelete :: SubHSetable els (Delete a els) eq => proxy a -> HSet els -> HSet (Delete a els)
- hnarrow :: SubHSetable els subels eq => proxy subels -> HSet els -> HSet subels
- hgetLabeled :: forall proxy label e els. HGetable els (Labeled label e) => proxy label -> HSet els -> e
- haskLabeled :: forall proxy label e els m. (HGetable els (Labeled label e), MonadReader (HSet els) m, Applicative m) => proxy label -> m e
- module Data.HSet.Labeled
Documentation
Heterogeneous set (list) of elements with unique types. Useful with MonadReader.
>>>
let x = HSCons (10 :: Int) $ HSCons (20 :: Double) HSNil
>>>
x
HSCons (10) (HSCons (20.0) (HSNil))
>>>
hget x :: Int
10
>>>
hget x :: Double
20.0
Note that hget
takes specific element from list of uniquely typed
elements depending on what type is required to be returned.
type HGetable els e = HGet els e (Index e els) Source
Enables deriving of the fact that e
is contained within els
and it's
safe to say that hget
can be performed on this particular pair.
hask :: (MonadReader (HSet els) m, HGetable els e) => m e Source
class (eq ~ TEq els els2) => SubHSet els els2 eq where Source
Takes subset of some hset, including subset of same elements in different order
>>>
let x = (HSCons "hello" $ HSCons 1234 $ HSCons 12.123 HSNil) :: HSet '[String, Int, Double]
>>>
subHSet x :: HSet '[Double, Int]
HSCons (12.123) (HSCons (1234) (HSNil))
>>>
subHSet x :: HSet '[String, Double]
HSCons ("hello") (HSCons (12.123) (HSNil))
>>>
subHSet x :: HSet '[Int, String]
HSCons (1234) (HSCons ("hello") (HSNil))
(~) Bool eq (TEq [*] els ([] *)) => SubHSet els ([] *) eq | |
(HGetable els el, (~) Bool False (Elem * el els2), SubHSet els els2 subeq, (~) [*] els ((:) * el els2), (~) Bool True (TEq [*] els ((:) * el els2))) => SubHSet els ((:) * el els2) True | |
(HGetable els el, (~) Bool False (Elem * el els2), SubHSet els els2 subeq, (~) Bool False (TEq [*] els ((:) * el els2))) => SubHSet els ((:) * el els2) False |
type SubHSetable els1 els2 eq = (SubHSet els1 els2 eq, eq ~ TEq els1 els2) Source
hdelete :: SubHSetable els (Delete a els) eq => proxy a -> HSet els -> HSet (Delete a els) Source
Removes element from HSet of specified type
>>>
let x = (HSCons "sdf" $ HSCons 123 HSNil) :: HSet '[String, Int]
>>>
hdelete (Proxy :: Proxy Int) x
HSCons ("sdf") (HSNil)
>>>
hdelete (Proxy :: Proxy String) x
HSCons (123) (HSNil)
hnarrow :: SubHSetable els subels eq => proxy subels -> HSet els -> HSet subels Source
Like subHSet
but with proxy for convenience
>>>
let x = (HSCons "hello" $ HSCons 123 $ HSCons 345 HSNil) :: HSet '[String, Int, Integer]
>>>
hnarrow (Proxy :: Proxy '[]) x
HSNil
>>>
hnarrow (Proxy :: Proxy '[String]) x
HSCons ("hello") (HSNil)
>>>
hnarrow (Proxy :: Proxy '[Int, Integer]) x
HSCons (123) (HSCons (345) (HSNil))
>>>
hnarrow (Proxy :: Proxy '[Integer, Int]) x
HSCons (345) (HSCons (123) (HSNil))
Work with Labeled
elements
hgetLabeled :: forall proxy label e els. HGetable els (Labeled label e) => proxy label -> HSet els -> e Source
>>>
let y = HSCons (Labeled 10 :: Labeled "x" Int) $ HSCons (Labeled 20 :: Labeled "y" Int) HSNil
>>>
y
HSCons (Labeled {unLabeled = 10}) (HSCons (Labeled {unLabeled = 20}) (HSNil))
>>>
hgetLabeled (Proxy :: Proxy "x") y :: Int
10
>>>
hgetLabeled (Proxy :: Proxy "y") y :: Int
20
haskLabeled :: forall proxy label e els m. (HGetable els (Labeled label e), MonadReader (HSet els) m, Applicative m) => proxy label -> m e Source
Reexports
module Data.HSet.Labeled