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 :++=(item: IterableOnce[A]): () => U
Implicitly added by setLens
def :++=(item: IterableOnce[A]): () => U
Implicitly added by seqLikeLens
def :+=(item: A): () => U
Implicitly added by setLens
def :+=(item: A): () => U
Implicitly added by seqLikeLens
def :=(a: A): () => Container

alias to set

alias to set

def apply(i: Int): Lens[U, A]
Implicitly added by seqLikeLens
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 foreach(f: Lens[A, A] => () => A): () => U
Implicitly added by setLens
def foreach(f: Lens[A, A] => () => A): () => U
Implicitly added by seqLikeLens
def head: Lens[U, A]
Implicitly added by seqLikeLens
def last: Lens[U, A]
Implicitly added by seqLikeLens
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.

Concrete fields

val lens: Lens[U, CC[A]]
Implicitly added by setLens
val lens: Lens[U, CC[A]]
Implicitly added by seqLikeLens