Safe Haskell | Safe-Inferred |
---|---|
Language | Haskell2010 |
Potentially uninitialised Booleans.
The motivation for this small library is to distinguish
between a boolean option with a default value and an option which has been
set to what happens to be the default value. In one case the default can be
overriden (e.g. --cubical
implies --without-K
) while in the other case the
user has made a mistake which they need to fix.
Synopsis
- data WithDefault' a (b :: Bool)
- type WithDefault b = WithDefault' Bool b
- setDefault :: Boolean a => a -> WithDefault' a b -> WithDefault' a b
- mapValue :: Boolean a => (a -> a) -> WithDefault' a b -> WithDefault' a b
- collapseDefault :: (Boolean a, KnownBool b) => WithDefault' a b -> a
- lensCollapseDefault :: (Boolean a, KnownBool b) => Lens' (WithDefault' a b) a
- lensKeepDefault :: (Boolean a, Eq a, KnownBool b) => Lens' (WithDefault' a b) a
Documentation
data WithDefault' a (b :: Bool) Source #
We don't want to have to remember for each flag whether its default value
is True
or False
. So we bake it into the representation: the flag's type
will mention its default value as a phantom parameter.
Instances
(EmbPrj a, Typeable b) => EmbPrj (WithDefault' a b) Source # | |
Defined in Agda.TypeChecking.Serialise.Instances.Common | |
Null (WithDefault' a b) Source # | The null value of 'WithDefault b' is |
Defined in Agda.Utils.WithDefault empty :: WithDefault' a b Source # null :: WithDefault' a b -> Bool Source # | |
Show a => Show (WithDefault' a b) Source # | |
Defined in Agda.Utils.WithDefault showsPrec :: Int -> WithDefault' a b -> ShowS # show :: WithDefault' a b -> String # showList :: [WithDefault' a b] -> ShowS # | |
NFData (WithDefault' a b) Source # | |
Defined in Agda.Utils.WithDefault rnf :: WithDefault' a b -> () # | |
Eq a => Eq (WithDefault' a b) Source # | |
Defined in Agda.Utils.WithDefault (==) :: WithDefault' a b -> WithDefault' a b -> Bool # (/=) :: WithDefault' a b -> WithDefault' a b -> Bool # |
type WithDefault b = WithDefault' Bool b Source #
setDefault :: Boolean a => a -> WithDefault' a b -> WithDefault' a b Source #
The main mode of operation of these flags, apart from setting them explicitly, is to toggle them one way or the other if they hadn't been set already.
mapValue :: Boolean a => (a -> a) -> WithDefault' a b -> WithDefault' a b Source #
Only modify non-Default
values.
collapseDefault :: (Boolean a, KnownBool b) => WithDefault' a b -> a Source #
Provided that the default value is a known boolean (in practice we only use
True
or False
), we can collapse a potentially uninitialised value to a boolean.
lensCollapseDefault :: (Boolean a, KnownBool b) => Lens' (WithDefault' a b) a Source #
Focus, overwriting Default
.
lensKeepDefault :: (Boolean a, Eq a, KnownBool b) => Lens' (WithDefault' a b) a Source #
Update, but keep Default
when new value is default value.