Lens

trait Lens[Container, A]
Companion
object
class Any
class ObjectLens[U, Container]

Value members

Abstract methods

def get(c: Container): A

get knows how to extract some field of type A from a container

get knows how to extract some field of type A from a container

def set(a: A): () => Container

Represents an assignment operator.

Represents an assignment operator.

Given a value of type A, sets knows how to transform a container such that a is assigned to the field.

We must have get(set(a)(c)) == a

Concrete methods

def :=(a: A): () => Container

alias to set

alias to set

def compose[B](other: Lens[A, B]): Lens[Container, B]

Composes two lenses, this enables nesting.

Composes two lenses, this enables nesting.

If our field of type A has a sub-field of type B, then given a lens for it (other: Lens[A, B]) we can create a single lens from Container to B.

def modify(f: A => A): () => Container

Represent an update operator (like x.y += 1 )

Represent an update operator (like x.y += 1 )

def setIfDefined(aOpt: Option[A]): () => Container

Optional assignment.

Optional assignment.

Given a Some[A], assign the Some's value to the field. Given None, the container is unchanged.

def zip[B](other: Lens[Container, B]): Lens[Container, (A, B)]

Given two lenses with the same origin, returns a new lens that can mutate both values represented by both lenses through a tuple.

Given two lenses with the same origin, returns a new lens that can mutate both values represented by both lenses through a tuple.