Контекст не может быть предоставлен без метода @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();

}