Packages

trait CanBindLocals[R] extends AnyRef

Type class describing how Local binding works for specific data types.

This is needed because asynchronous data types, like Future, that can be waited on, should also clear the modified context after completion.

NOTE: this type class does not work for data types that suspend the execution, like Coeval or Task, because Local is meant to be used in a side effectful way. Instances of this type class can't be implemented for data types like Task, as a technical limitation, because Task would also need a suspended Context evaluation in bindContext.

Annotations
@implicitNotFound("""Cannot find an implicit value for CanBindLocals[${R}].
If ${R} is the result of a synchronous action, either build an implicit with
CanBindLocals.synchronous or import CanBindLocals.Implicits.synchronousAsDefault."""
)
Source
CanBindLocals.scala
Linear Supertypes
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. CanBindLocals
  2. AnyRef
  3. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. Protected

Abstract Value Members

  1. abstract def bindContext(ctx: Context)(f: => R): R

    See Local.bind.

Concrete Value Members

  1. def bindKey[A](local: Local[A], value: Option[A])(f: => R): R

    See Local.bind.

  2. def isolate(f: => R): R

    See Local.isolate.