| Copyright | (c) 2019 Lucas David Traverso | 
|---|---|
| License | MPL-2.0 | 
| Maintainer | Lucas David Traverso <[email protected]> | 
| Stability | stable | 
| Portability | portable | 
| Safe Haskell | Safe-Inferred | 
| Language | Haskell2010 | 
Conferer.Key
Description
Public API for Key related features
Documentation
This type is used extensivelly as a way to point into a Source
   and in turn into a Config. The intended way to create them is
   is using mkKey.
It's a list of alphanumeric words and each Source can interpret
   it as it sees fit.
Creating Keys
mkKey :: String -> Key Source #
Helper function to create Keys, this function always works, but
   since Keys reject some string this function transforms the input
   to provide lawful Keys instead of throwing.
For example:
'mkKey' "sOmE.KEy" == "some.key" 'mkKey' "1.key" == "1.key" 'mkKey' "1_thing.key" == "1thing.key" 'mkKey' "some....key" == "some.key" 'mkKey' ".." == ""
Maniputaing Keys
stripKeyPrefix :: Key -> Key -> Maybe Key Source #
Given k1 and k2 this function drops k1 as a prefix from k2, if
   k1 is not a prefix of k2 it returns Nothing
'keyPrefixOf' "foo" "foo.bar" == Just "bar" 'keyPrefixOf' "foo" "foo" == Just "" 'keyPrefixOf' "foo" "fooa" == Nothing 'keyPrefixOf' "" k == Just k
isKeyPrefixOf :: Key -> Key -> Bool Source #
This function tells if a key is a subkey of another key based using key fragments instead of letters as units
'isKeyPrefixOf' "foo" "foo.bar" == True 'isKeyPrefixOf' "foo" "foo" == True 'isKeyPrefixOf' "foo" "fooa" == False
Introspecting Keys
rawKeyComponents :: Key -> [Text] Source #
Get raw components from a key, usually to do some manipulation