2022-03-16 追記: 新しいDagger記事は以下リンクから
👉 MVVM で Hilt のパターン化 💉 data:image/s3,"s3://crabby-images/7916e/7916ef17240eaff8fb4e76b4568dc64c5a5340d4" alt=""
--------
へん‐せん【変遷】
[名](スル)時の流れとともに移り変わること。「歌もまた時代につれて変遷する」
Dagger て分かりづらいです。
タイトルがすでに謎ですが、以下のような実装のことを指しています。
アプリケーションコンテキストをオブジェクトグラフに追加する
ApplicationComponent とアプリケーションコンテキストの設定
アプリケーションコンテキスト を依存先として公開する
これまで数年に渡って変化し続けてるそんな必須の実装項目です。
ネット上をただ検索するだけでは、古い記事に最新の実装記述が埋没しています。
Dagger 2.9 以前( - 2017/02/04)
@Component(modules = [ApplicationModule::class, ...])
interface ApplicationComponent {
...
}
@Module
class ApplicationModule(private val applicationContext: Context) {
@Provides fun provideApplicationContext() = applicationContext
}
これは Kotlin 記述で簡略化できます。
@Module
class ApplicationModule(@get:Provides val applicationContext: Context)
DaggerApplicationComponent
.builder()
.applicationModule(ApplicationModule(applicationContext))
.build()
2.9 (2017/02/04 - ) @BindsInstance
👉 Release Dagger 2.9 · google/dagger data:image/s3,"s3://crabby-images/ceb76/ceb7687f03fc84e8754c0cf9a60f2df6d92a88c9" alt=""
We create a module that receives the application context as a constructor argument, and we create a provide method that exposes it. This works great, but then we can't have static @Provides methods anymore. And besides that, this strategy is actually going against the docs that are pretty explicit when it comes to this:
@BindsInstance methods should be preferred to writing a @Module with constructor arguments and immediately providing those values.
👉 User's Guide data:image/s3,"s3://crabby-images/dcb4e/dcb4e581664018881104b815e990b1d8a7600b79" alt=""
@Component(modules = ...)
interface ApplicationComponent {
@Component.Builder
interface Builder {
@BindsInstance
fun applicationContext(applicationContext: Context): Builder
fun build(): ApplicationComponent
}
...
}
DaggerApplicationComponent
.builder()
.applicationContext(applicationContext)
.build()
2.22 (2019/04/03 - ) @Component.Factory
👉 Release Dagger 2.22 · google/dagger data:image/s3,"s3://crabby-images/556f6/556f60c71267469c4f8acb8d7ed0856339820846" alt=""
@Component(modules = ...)
interface ApplicationComponent {
@Component.Factory
interface Factory {
fun create(@BindsInstance applicationContext: Context): ApplicationComponent
}
...
}
DaggerApplicationComponent
.factory()
.create(applicationContext)
まとめ
最近のコード記述を理解するには、少しだけ
「成り立ちを遡ってみる」
と理解しやすいことが多いように思います。
👉 Releases · google/dagger data:image/s3,"s3://crabby-images/4f614/4f6141ca23f15f7871151943c5e09c5ab6a1559f" alt=""
👉 Dagger 2 on Android: the shiny new @Component.Factory data:image/s3,"s3://crabby-images/d6a26/d6a26db34807981153bf962567dd6a3abe72dbc3" alt=""
2022-03-16 追記: 新しいDagger記事は以下リンクから
👉 MVVM で Hilt のパターン化 💉 data:image/s3,"s3://crabby-images/7916e/7916ef17240eaff8fb4e76b4568dc64c5a5340d4" alt=""