| Copyright | (C) 2017 Csongor Kiss |
|---|---|
| License | BSD3 |
| Maintainer | Csongor Kiss <kiss.csongor.kiss@gmail.com> |
| Stability | experimental |
| Portability | non-portable |
| Safe Haskell | Safe |
| Language | Haskell2010 |
Data.Generics.Product.Fields
Contents
Description
Derive record field getters and setters generically.
Lenses
Running example:
>>>:set -XTypeApplications>>>:set -XDataKinds>>>:set -XDeriveGeneric>>>:set -XGADTs>>>:set -XFlexibleContexts>>>import GHC.Generics>>>:m +Data.Generics.Internal.Lens>>>:m +Data.Function>>>:{data Human a = Human { name :: String , age :: Int , address :: String , other :: a } | HumanNoAddress { name :: String , age :: Int , other :: a } deriving (Generic, Show) human :: Human Bool human = Human { name = "Tunyasz", age = 50, address = "London", other = False } :}
class HasField (field :: Symbol) s t a b | s field -> a, s field b -> t where #
Records that have a field with a given name.
Minimal complete definition
Methods
A lens that focuses on a field with a given name. Compatible with the
lens package's Lens type.
>>>human ^. field @"age"50
Type changing
>>>:t humanhuman :: Human Bool
>>>:t human & field @"other" .~ (42 :: Int)human & field @"other" .~ (42 :: Int) :: Human Int
>>>human & field @"other" .~ 42Human {name = "Tunyasz", age = 50, address = "London", other = 42}
Type errors
>>>human & field @"weight" .~ 42... ... The type Human Bool does not contain a field named 'weight'. ...
>>>human & field @"address" .~ ""... ... Not all constructors of the type Human Bool ... contain a field named 'address'. ... The offending constructors are: ... HumanNoAddress ...
Instances