Packages

trait LocatorDef extends AbstractLocator with AbstractBindingDefDSL[BindDSL, BindDSLUnnamedAfterFrom, SetDSL]

Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. LocatorDef
  2. AbstractBindingDefDSL
  3. AbstractBindingDefDSLMacro
  4. AbstractLocator
  5. Locator
  6. AnyRef
  7. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. Protected

Type Members

  1. final class MutationContext extends AnyRef

    Use this to create utility functions that add bindings mutably to the current module, as opposed to creating new modules and including them.

    Use this to create utility functions that add bindings mutably to the current module, as opposed to creating new modules and including them.

    Example:

    import distage.{ClassConstructor, Tag, ModuleDef}
    import izumi.distage.model.definition.dsl.ModuleDefDSL
    
    trait RegisteredComponent
    class RegisteredComponentImpl extends RegisteredComponent
    
    def addAndRegister[T <: RegisteredComponent: Tag: ClassConstructor](implicit mutateModule: ModuleDefDSL#MutationContext): Unit = {
      new mutateModule.dsl {
        make[T]
    
        many[RegisteredComponent]
          .weak[T]
      }
    }
    
    new ModuleDef {
      addAndRegister[RegisteredComponentImpl]
    }
    Definition Classes
    AbstractBindingDefDSL

Value Members

  1. final def !=(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  2. final def ##: Int
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  4. def _initialState: ArrayBuffer[BindingRef]
    Attributes
    protected
    Definition Classes
    AbstractBindingDefDSL
  5. final def _make[T](provider: Functoid[T])(implicit arg0: Tag[T], pos: CodePositionMaterializer): BindDSL[T]
    Attributes
    protected
    Definition Classes
    AbstractBindingDefDSL
  6. def _registered[T <: BindingRef](bindingRef: T): T
    Attributes
    protected
    Definition Classes
    AbstractBindingDefDSL
  7. final def addImplicit[T](implicit arg0: Tag[T], instance: T, pos: CodePositionMaterializer): BindDSLUnnamedAfterFrom[T]

    Same as make[T].from(implicitly[T]) *

    Same as make[T].from(implicitly[T]) *

    Attributes
    protected
    Definition Classes
    AbstractBindingDefDSL
  8. final def allInstances: Seq[IdentifiedRef]

    returns

    ALL instances contained in this locator and in all the parent locators, including injector bootstrap environment. Returned keys may overlap if parent locators contain objects for the same key. Instances from parent locators will be earlier in the list than instances from this locator.

    Definition Classes
    Locator
    See also

    izumi.distage.bootstrap.BootstrapLocator

  9. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  10. def clone(): AnyRef
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.CloneNotSupportedException]) @native()
  11. final def depth: Int
    Definition Classes
    Locator
  12. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  13. def equals(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef → Any
  14. def finalize(): Unit
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.Throwable])
  15. def finalizers[F[_]](implicit arg0: TagK[F]): Seq[Finalizer[F]]
    Definition Classes
    LocatorDefLocator
  16. final def find[T](id: Identifier)(implicit arg0: Tag[T]): Option[T]
    Definition Classes
    AbstractLocatorLocator
  17. final def find[T](implicit arg0: Tag[T]): Option[T]
    Definition Classes
    AbstractLocatorLocator
  18. final def get[T](id: Identifier)(implicit arg0: Tag[T]): T
    Definition Classes
    AbstractLocatorLocator
  19. final def get[T](implicit arg0: Tag[T]): T
    Definition Classes
    AbstractLocatorLocator
  20. final def getClass(): Class[_ <: AnyRef]
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  21. def hashCode(): Int
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  22. def index: Map[DIKey, Any]

    returns

    *Only* instances directly contained in this Locator, *NOT* instances in its parent Locators. Returned keys will be unique.

    Definition Classes
    LocatorDefLocator
  23. def instances: Seq[IdentifiedRef]

    Objects in this locator in order of creation

    Objects in this locator in order of creation

    returns

    *Only* instances directly contained in this Locator, *NOT* instances in its parent Locators. Returned keys will be unique.

    Definition Classes
    LocatorDefLocator
  24. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  25. def isPrivate(key: DIKey): Boolean
    Definition Classes
    LocatorDefLocator
  26. final def lookupInstance[T](key: DIKey)(implicit arg0: Tag[T]): Option[T]
    Definition Classes
    AbstractLocatorLocator
  27. final def lookupInstanceOrThrow[T](key: DIKey)(implicit arg0: Tag[T]): T
    Definition Classes
    AbstractLocatorLocator
  28. def lookupLocalUnsafe(key: DIKey): Option[Any]
    Attributes
    protected
    Definition Classes
    LocatorDefAbstractLocator
  29. final def lookupRef[T](key: DIKey)(implicit arg0: Tag[T]): Option[GenericTypedRef[T]]
    Definition Classes
    AbstractLocatorLocator
  30. final def lookupRefOrThrow[T](key: DIKey)(implicit arg0: Tag[T]): GenericTypedRef[T]
    Definition Classes
    AbstractLocatorLocator
  31. final macro def make[T]: BindDSL[T]
    Attributes
    protected
    Definition Classes
    AbstractBindingDefDSLMacro
  32. final def makeFactory[T](implicit arg0: Tag[T], arg1: FactoryConstructor[T]): BindDSLUnnamedAfterFrom[T]

    Attributes
    protected
    Definition Classes
    AbstractBindingDefDSL
    See also

    Auto-Factories feature

  33. final def makeSubcontext[T](implicit arg0: Tag[T]): SubcontextDSL[T]

    Attributes
    protected
    Definition Classes
    AbstractBindingDefDSL
    See also

    Subcontexts feature

  34. final def makeSubcontext[T](submodule: ModuleBase)(implicit arg0: Tag[T]): SubcontextDSL[T]

    Attributes
    protected
    Definition Classes
    AbstractBindingDefDSL
    See also

    Subcontexts feature

  35. final def makeTrait[T](implicit arg0: Tag[T], arg1: TraitConstructor[T]): BindDSLUnnamedAfterFrom[T]

    Attributes
    protected
    Definition Classes
    AbstractBindingDefDSL
    See also

    Auto-Traits feature

  36. final def many[T](implicit tag: Tag[Set[T]], pos: CodePositionMaterializer): SetDSL[T]

    Set bindings are useful for implementing event listeners, plugins, hooks, http routes, etc.

    Set bindings are useful for implementing event listeners, plugins, hooks, http routes, etc.

    To define a multibinding use .many and .add methods in ModuleDef DSL:

    import cats.effect._, org.http4s._, org.http4s.dsl.io._, scala.concurrent.ExecutionContext.Implicits.global
    import distage._
    
    object HomeRouteModule extends ModuleDef {
      many[HttpRoutes[IO]].add {
        HttpRoutes.of[IO] { case GET -> Root / "home" => Ok(s"Home page!") }
      }
    }

    Set bindings defined in different modules will be merged together into a single Set. You can summon a created Set by type Set[T]:

    import cats.implicits._, org.http4s.server.blaze._, org.http4s.implicits._
    
    object BlogRouteModule extends ModuleDef {
      many[HttpRoutes[IO]].add {
        HttpRoutes.of[IO] { case GET -> Root / "blog" / post => Ok("Blog post ``$post''!") }
      }
    }
    
    class HttpServer(routes: Set[HttpRoutes[IO]]) {
      val router = routes.foldK
    
      def serve = BlazeBuilder[IO]
        .bindHttp(8080, "localhost")
        .mountService(router, "/")
        .start
    }
    
    val objects = Injector().produce(HomeRouteModule ++ BlogRouteModule)
    val server = objects.get[HttpServer]
    
    val testRouter = server.router.orNotFound
    
    testRouter.run(Request[IO](uri = uri("/home"))).flatMap(_.as[String]).unsafeRunSync
    // Home page!
    
    testRouter.run(Request[IO](uri = uri("/blog/1"))).flatMap(_.as[String]).unsafeRunSync
    // Blog post ``1''!
    Attributes
    protected
    Definition Classes
    AbstractBindingDefDSL
    See also

    Guice wiki on Multibindings: https://github.com/google/guice/wiki/Multibindings

  37. def meta: LocatorMeta
    Definition Classes
    LocatorDefLocator
  38. final def modify[T]: ModifyDSL[T, BindDSL, BindDSLUnnamedAfterFrom, SetDSL]

    Modify a value bound at T.

    Modify a value bound at T. Modifiers stack and are all applied before T is added to the object graph; only the final instance is observable.

    import distage.{Injector, ModuleDef}
    
    Injector().produceGet[Int](new ModuleDef {
      make[Int].from(1)
      modify[Int](_ + 1)
      modify[Int](_ + 1)
    }).use(i => println(s"Got `Int` $i"))
    // Got `Int` 3

    You can also modify while summoning additional dependencies:

    modify[Int]("named").by(_.flatAp {
      (adder: Adder, multiplier: Multiplier) =>
        int: Int =>
          multiplier.multiply(adder.add(int, 1), 10)
    })
    Attributes
    protected
    Definition Classes
    AbstractBindingDefDSL
  39. implicit final lazy val mutationContext: MutationContext
    Attributes
    protected
    Definition Classes
    AbstractBindingDefDSL
  40. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  41. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  42. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  43. def parent: Option[Locator]
    Definition Classes
    LocatorDefLocator
  44. def plan: Plan

    The plan that produced this object graph

    The plan that produced this object graph

    Definition Classes
    LocatorDefLocator
  45. def render()(implicit ev: Renderable[Locator]): String
    Definition Classes
    Locator
  46. final def run[T](function: Functoid[T]): T

    Run function filling all the arguments from the object graph.

    Run function filling all the arguments from the object graph.

    Works similarly to function bindings in izumi.distage.model.definition.ModuleDef.

    objects.run {
      (hellower: Hellower, bye: Byer) =>
        hellower.hello()
        byer.bye()
    }
    Definition Classes
    Locator
    See also

    izumi.distage.model.providers.Functoid

  47. final def runOption[T](function: Functoid[T]): Option[T]

    Same as run but returns None if any of the arguments could not be fulfilled

    Same as run but returns None if any of the arguments could not be fulfilled

    Definition Classes
    Locator
  48. final def synchronized[T0](arg0: => T0): T0
    Definition Classes
    AnyRef
  49. def toString(): String
    Definition Classes
    Locator → AnyRef → Any
  50. final def todo[T](implicit arg0: Tag[T], pos: CodePositionMaterializer): BindDSLUnnamedAfterFrom[T]

    Create a dummy binding that throws an exception with an error message when it's created.

    Create a dummy binding that throws an exception with an error message when it's created.

    Useful for prototyping.

    Attributes
    protected
    Definition Classes
    AbstractBindingDefDSL
  51. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  52. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  53. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException]) @native()

Inherited from AbstractLocator

Inherited from Locator

Inherited from AnyRef

Inherited from Any

Ungrouped