generic-lens-1.2.0.1: Generically derive traversals, lenses and prisms.

Copyright(C) 2019 Csongor Kiss
LicenseBSD3
MaintainerCsongor Kiss <kiss.csongor.kiss@gmail.com>
Stabilityexperimental
Portabilitynon-portable
Safe HaskellNone
LanguageHaskell2010

Data.Generics.Product.Positions

Contents

Description

Derive positional product type getters and setters generically.

Synopsis

Lenses

Running example:

>>> :set -XTypeApplications
>>> :set -XDataKinds
>>> :set -XDeriveGeneric
>>> :set -XGADTs
>>> :set -XFlexibleContexts
>>> import GHC.Generics
>>> :m +Data.Generics.Internal.VL.Lens
>>> :m +Data.Function
>>> :{
data Human = Human
  { name    :: String
  , age     :: Int
  , address :: String
  }
  deriving (Generic, Show)
human :: Human
human = Human "Tunyasz" 50 "London"
:}

class HasPosition (i :: Nat) s t a b | s i -> a, t i -> b, s i b -> t, t i a -> s where Source #

Records that have a field at a given position.

Methods

position :: Lens s t a b Source #

A lens that focuses on a field at a given position. Compatible with the lens package's Lens type.

>>> human ^. position @1
"Tunyasz"
>>> human & position @3 .~ "Berlin"
Human {name = "Tunyasz", age = 50, address = "Berlin"}

Type errors

>>> human & position @4 .~ "Berlin"
...
... The type Human does not contain a field at position 4
...
Instances
(ErrorUnless i s ((0 <? i) && (i <=? Size (Rep s))), HasTotalPositionP i (CRep s) ~~ Just a, HasTotalPositionP i (CRep t) ~~ Just b, HasTotalPositionP i (CRep (Indexed s)) ~~ Just a', HasTotalPositionP i (CRep (Indexed t)) ~~ Just b', t ~~ Infer s a' b, s ~~ Infer t b' a, Coercible (CRep s) (Rep s), Coercible (CRep t) (Rep t), HasPosition0 i s t a b) => HasPosition i s t a b Source # 
Instance details

Defined in Data.Generics.Product.Positions

Methods

position :: Lens s t a b Source #

HasPosition f (Void1 a) (Void1 b) a b Source #

See Note [Uncluttering type signatures]

Instance details

Defined in Data.Generics.Product.Positions

Methods

position :: Lens (Void1 a) (Void1 b) a b Source #

class HasPosition' (i :: Nat) s a | s i -> a where Source #

Records that have a field at a given position.

The difference between HasPosition and HasPosition_ is similar to the one between HasField and HasField_. See HasField_.

Methods

position' :: Lens s s a a Source #

Instances
(Generic s, ErrorUnless i s ((0 <? i) && (i <=? Size (Rep s))), cs ~ CRep s, Coercible (Rep s) cs, GLens' (HasTotalPositionPSym i) cs a, Defined (Rep s) (NoGeneric s (Text "arising from a generic lens focusing on the field at" ': ((((((Text "position " :<>: QuoteType i) :<>: Text " of type ") :<>: QuoteType a) :<>: Text " in ") :<>: QuoteType s) ': ([] :: [ErrorMessage])))) ()) => HasPosition' i s a Source # 
Instance details

Defined in Data.Generics.Product.Positions

Methods

position' :: Lens s s a a Source #

class HasPosition_ (i :: Nat) s t a b where Source #

Methods

position_ :: Lens s t a b Source #

Instances
(ErrorUnless i s ((0 <? i) && (i <=? Size (Rep s))), UnifyHead s t, UnifyHead t s, Coercible (CRep s) (Rep s), Coercible (CRep t) (Rep t), HasPosition0 i s t a b) => HasPosition_ i s t a b Source # 
Instance details

Defined in Data.Generics.Product.Positions

Methods

position_ :: Lens s t a b Source #

HasPosition_ f (Void1 a) (Void1 b) a b Source # 
Instance details

Defined in Data.Generics.Product.Positions

Methods

position_ :: Lens (Void1 a) (Void1 b) a b Source #

class HasPosition0 (i :: Nat) s t a b where Source #

Records that have a field at a given position.

This class gives the minimal constraints needed to define this lens. For common uses, see HasPosition.

Methods

position0 :: Lens s t a b Source #

Instances
(Generic s, Generic t, GLens (HasTotalPositionPSym i) (CRep s) (CRep t) a b, Coercible (CRep s) (Rep s), Coercible (CRep t) (Rep t), Defined (Rep s) (NoGeneric s (Text "arising from a generic lens focusing on the field at" ': ((((((Text "position " :<>: QuoteType i) :<>: Text " of type ") :<>: QuoteType a) :<>: Text " in ") :<>: QuoteType s) ': ([] :: [ErrorMessage])))) ()) => HasPosition0 i s t a b Source # 
Instance details

Defined in Data.Generics.Product.Positions

Methods

position0 :: Lens s t a b Source #

getPosition :: forall i s a. HasPosition' i s a => s -> a Source #

>>> getPosition @2 human
50

setPosition :: forall i s a. HasPosition' i s a => a -> s -> s Source #

>>> setPosition @2 60 human
Human {name = "Tunyasz", age = 60, address = "London"}