Kotlin 2.0 に移行する
Android 向け Consumer SDK 3.0 以降を使用している場合は、Kotlin 2.0 にアップグレードする必要があります。このページでは、新しい Kotlin バージョンへの移行を容易にするためのガイダンスを提供します。
Gradle と AGP の互換性
Kotlin 2.0 には、Gradle と Android Gradle プラグイン(AGP)のバージョンの最小バージョンと最大 バージョンの 要件があります。プロジェクトが Kotlin 2.0 のこれらの要件を満たしていることを確認してください。
Consumer SDK 3.0 以降の AGP の最小バージョン
Consumer SDK 3.0 では、AGP 7.3 以降を使用する必要があります。
R8 フルモード
Consumer SDK v3 以前では、R8 フルモードはサポートされていません。アプリケーションのターゲットが AGP 8.0 以降の場合は、R8 フルモードを明示的に無効にする必要があります。
# settings.gradle
android.enableR8.fullMode=false
Kotlin のバージョン互換性
Kotlin は、3 つ前の言語 バージョンとの下位互換性をサポートしています。 つまり、Consumer SDK で Kotlin 1.7 以降をすでに使用している場合は、互換性を破る変更をすべて解決しなくても Kotlin 2.0 にアップグレードできるはずです。ただし、Kotlin の互換性は安定版の言語 機能にのみ適用されます。 Kotlin 言語でアルファ版、ベータ版、試験運用版の機能を使用している場合は、アップグレード時に追加の変更が必要になることがあります。
Kotlin の互換性フラグ
前のセクションで説明したように、Kotlin はアップグレード時に最大 3 つ前の言語バージョンをサポートします。Kotlin には、互換性を破る変更を制限するのに役立つ 2 つのフラグが用意されています。
language-version X.Y
このフラグは、互換性を破る変更を以前の Kotlin バージョンの動作に戻します。
たとえば、Kotlin 1.7 を使用している場合は、[ -
language-version 1.7] を指定すると、新しい互換性を破る変更は有効になりません。
android {
kotlinOptions {
languageVersion = '1.7'
}
}
api-version X.Y
このフラグを使用すると、依存するダウンストリーム コードが Kotlin 2.0 を組み込む準備が整うまで、新しい API の使用を禁止できます。
android {
kotlinOptions {
apiVersion = '1.7'
}
}
よりターゲットを絞ったアプローチ
Kotlin の互換性フラグを使用するだけでなく、Kotlin のリリースノートを確認し、アップグレード元のバージョンから保持する動作を選択することをおすすめします。Kotlin では、各バージョンの互換性ガイドで、互換性を破る変更のリストと、元の動作を保持するために設定できるフラグを提供しています。