Ошибка при предоставлении экземпляра, который имеет зависимость мульти-связывания Dagger - PullRequest
0 голосов
/ 17 января 2019

Я получаю сообщение об ошибке при запуске следующего кода. Я пытаюсь внедрить карту, созданную с помощью мультисвязывания Dagger, в экземпляр D методом @Provides.

Ошибка:

error: [Dagger/MissingBinding] java.util.Map<java.lang.Class<dagger.A>,java.lang.String> cannot be provided without an @Provides-annotated method.
public abstract dagger.D d();
                         ^
  java.util.Map<java.lang.Class<dagger.A>,java.lang.String> is injected at
      dagger.ModuleA.provideD(map)
  dagger.D is provided at
      dagger.ComponentA.d()

Код:

open class A
class B : A()
class C : A()
data class D(val map: Map<Class<A>, String>)

@Module
object ModuleA {

    @JvmStatic
    @Provides
    @IntoMap()
    @ClassKey(B::class)
    fun provideB(): String {
        return "B"
    }

    @JvmStatic
    @Provides
    @IntoMap()
    @ClassKey(C::class)
    fun provideC(): String {
        return "C"
    }

    @JvmStatic
    @Provides
    fun provideD(map: Map<Class<A>, String>): D {
        return D(map)
    }
}

@Component(modules = [ModuleA::class])
@Singleton
interface ComponentA {
    fun d(): D
}

fun main(args : Array<String>) {
    val dagger = DaggerComponentA.builder().build()
    println(dagger.d())
}

Я не могу найти прямых примеров этого. Я нахожу только примеры, которые используют полевую инъекцию самой карты.

Поддерживается ли то, что я пытаюсь?

1 Ответ

0 голосов
/ 17 января 2019

Я понял это:

open class A
class B : A()
class C : A()
data class D(val map: Map<Class<out A>, String>)

@MapKey
internal annotation class MyClassKey(val value: KClass<out A>)

@Module
object ModuleA {

    @JvmStatic
    @Provides
    @IntoMap()
    @MyClassKey(B::class)
    fun provideB(): String {
        return "B"
    }

    @JvmStatic
    @Provides
    @IntoMap()
    @MyClassKey(C::class)
    fun provideC(): String {
        return "C"
    }

    @JvmStatic
    @Provides
    @IntoMap()
    @MyClassKey(A::class)
    fun provideA(): String {
        return "A"
    }

    @JvmStatic
    @Provides
    fun provideD(map: Map<Class<out A>, String>): D {
        return D(map)
    }
}

@Component(modules = [ModuleA::class])
@Singleton
interface ComponentA {
    fun d(): D
}

fun main(args : Array<String>) {
    val dagger = DaggerComponentA.builder().build()
    val d = dagger.d()
    println(d.map) // {class dagger.B=B, class dagger.C=C, class dagger.A=A}
}

Мне нужно было предоставить пользовательскую аннотацию @MapKey:

@MapKey
internal annotation class MyClassKey(val value: KClass<out A>)

и изменить

fun provideD(map: Map<Class<A>, String>): D { 

до

fun provideD(map: Map<Class<out A>, String>): D {
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...