Контекст не может быть предоставлен без метода @Provides-annotated, но это так?
У меня есть следующий простой модуль:
@Module
public class ApplicationModule {
private CustomApplication customApplication;
public ApplicationModule(CustomApplication customApplication) {
this.customApplication = customApplication;
}
@Provides @Singleton CustomApplication provideCustomApplication() {
return this.customApplication;
}
@Provides @Singleton @ForApplication Context provideApplicationContext() {
return this.customApplication;
}
}
И соответствующий простой компонент:
@Singleton
@Component(
modules = ApplicationModule.class
)
public interface ApplicationComponent {
CustomApplication getCustomApplication();
Context getApplicationContext();
}
И я создаю компонент здесь:
public class CustomApplication extends Application {
...
private ApplicationComponent component;
@Override
protected void attachBaseContext(Context base) {
super.attachBaseContext(base);
MultiDex.install(this);
}
@Override
public void onCreate() {
super.onCreate();
component = DaggerApplicationComponent.builder()
.applicationModule(new ApplicationModule(this))
.build();
Он выдает эту ошибку во время компиляции: Error:(22, 13) error: android.content.Context cannot be provided without an @Provides-annotated method
, но, как вы видите, она аннотируется с помощью @Provides
.
Это действительно странно, потому что проблема исчезает, когда я снимаю аннотацию классификатора.
На всякий случай, это мой @ForApplication
классификатор:
@Qualifier @Retention(RUNTIME)
public @interface ForApplication {
}
Это пример учебника Dagger2. Что я делаю неправильно?
Ответы
Ответ 1
По прошествии некоторого времени проб и ошибок я, кажется, нашел причину, это двусмысленность Context
, потому что @ForApplication
отсутствует в некоторых местах, где требуется Context
.
И это может быть мое слабое понимание Dagger2 на данный момент, но этот шаблонный план очень склонен к ошибкам разработчиков.
В любом случае... для тех, кто находит проблему, вам просто нужно добавить аннотации классификатора в каждом месте, где используется зависимость:
@Singleton
@Component(
modules = ApplicationModule.class
)
public interface ApplicationComponent {
CustomApplication getCustomApplication();
@ForApplication Context getApplicationContext();
}