GeneratedExtension

case class GeneratedExtension[C <: ExtendableMessage[C], T](lens: Lens[C, T]) extends Lens[C, T]
Companion:
object
trait Product
trait Equals
trait Lens[C, T]
trait Serializable
class Object
trait Matchable
class Any

Value members

Concrete methods

def get(c: C): T

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(t: T): () => C

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

def withLens[B](other: Lens[T, B]): GeneratedExtension[C, B]

Inherited methods

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

alias to set

alias to set

Inherited from:
Lens
def compose[B](other: Lens[T, 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.

Inherited from:
Lens
def modify(f: T => T): () => Container

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

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

Inherited from:
Lens
def productElementNames: Iterator[String]
Inherited from:
Product
def productIterator: Iterator[Any]
Inherited from:
Product
def setIfDefined(aOpt: Option[T]): () => Container

Optional assignment.

Optional assignment.

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

Inherited from:
Lens
def zip[B](other: Lens[C, 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.

Inherited from:
Lens