| Copyright | (c) 2018-2022 Kowainik | 
|---|---|
| License | MPL-2.0 | 
| Maintainer | Kowainik <xrom.xkov@gmail.com> | 
| Stability | Stable | 
| Portability | Portable | 
| Safe Haskell | Safe-Inferred | 
| Language | Haskell2010 | 
Toml.Codec.Di
Description
Forward and backward mapping functions and combinators (similar to profunctors).
Since: 1.3.0.0
Synopsis
Documentation
Arguments
| :: (b -> a) | Mapper for consumer | 
| -> (a -> b) | Mapper for producer | 
| -> TomlCodec a | Source  | 
| -> TomlCodec b | Target  | 
This is an instance of Profunctor for Codec. But since there's no
Profunctor type class in base or package with no dependencies (and we don't
want to bring extra dependencies) this instance is implemented as a single
top-level function.
Useful when you want to parse newtypes. For example, if you had data type like
this:
data Example = Example
    { foo :: Bool
    , bar :: Text
    }
Bidirectional TOML converter for this type will look like this:
exampleCodec :: TomlCodec Example
exampleCodec = Example
    <$> Toml.bool "foo" .= foo
    <*> Toml.text "bar" .= bar
Now if you change your type in the following way:
newtype Email = Email { unEmail :: Text }
data Example = Example
    { foo :: Bool
    , bar :: Email
    }
you need to patch your TOML codec like this:
exampleCodec :: TomlCodec Example
exampleCodec = Example
    <$> Toml.bool "foo" .= foo
    <*> dimap unEmail Email (Toml.text "bar") .= bar
Since: 0.2.0
dioptional :: TomlCodec a -> TomlCodec (Maybe a) Source #
Bidirectional converter for Maybe a values. For example, given the data
type:
data Example = Example
    { foo :: Bool
    , bar :: Maybe Int
    }
the TOML codec will look like
exampleCodec :: TomlCodec Example
exampleCodec = Example
    <$> Toml.bool "foo" .= foo
    <*> dioptional (Toml.int "bar") .= bar
Since: 0.5.0
Arguments
| :: (b -> Maybe a) | Mapper for consumer | 
| -> (a -> b) | Mapper for producer | 
| -> TomlCodec a | Source  | 
| -> TomlCodec b | Target  | 
Bidirectional converter for sum types. For example, given the data
type:
data Example
    = Foo Int
    | Bar Bool Int
the TOML codec will look like
matchFoo :: Example -> Maybe Int
matchFoo (Foo num) = Just num
matchFoo _         = Nothing
matchBar :: Example -> Maybe (Bool, Int)
matchBar (Bar b num) = Just (b, num)
matchBar _           = Nothing
barCodec :: TomlCodec (Bool, Int)
barCodec = Toml.pair
    (Toml.bool "a")
    (Toml.int "b")
exampleCodec :: TomlCodec Example
exampleCodec =
    dimatch matchFoo Foo (Toml.int "foo")
    <|> dimatch matchBar (uncurry Bar) (Toml.table barCodec "bar")
Since: 1.2.0.0