Руководство по миграции Android Driver SDK 6.0

Переход на интерфейс DriverStatusListener

В Driver v5 мы объявили об отказе от интерфейса StatusListener в пользу DriverStatusListener . В этом году мы официально удаляем интерфейс StatusListener . Инструкции по переходу на новый интерфейс см. в разделе «Устаревание StatusListener .

Переход на Котлин 2.0

Если вы используете Driver SDK для Android 6.0+, вам необходимо выполнить обновление до Kotlin 2.0. На этой странице представлены рекомендации по облегчению перехода на новую версию Kotlin.

Совместимость Gradle и AGP

Kotlin 2.0 предъявляет требования к минимальной и максимальной версиям вашей версии Gradle и Android Gradle Plugin (AGP). Убедитесь, что ваш проект соответствует этим требованиям для Kotlin 2.0.

Минимальная версия AGP для Driver SDK 6.0+

Мы рекомендуем использовать AGP 7.3+ с Driver SDK 6.0.

Полный режим R8

Driver SDK v6 и ниже не поддерживает режим Full R8. Вы должны явно отключить режим Full R8, если ваше приложение предназначено для AGP 8.0+.

# settings.gradle
android.enableR8.fullMode=false

Совместимость версий Котлина

Kotlin поддерживает обратную совместимость с тремя предыдущими языковыми версиями . Это означает, что если вы уже используете Kotlin 1.7+ с Driver SDK, вы сможете перейти на Kotlin 2.0 без необходимости внесения всех критических изменений. Однако совместимость с Kotlin применима только к стабильным функциям языка . Если вы используете альфа-, бета-версию или экспериментальные функции языка Kotlin, возможно, вам придется внести дополнительные изменения при обновлении.

Флаги совместимости Kotlin

Как отмечалось в предыдущем разделе, Kotlin при обновлении поддерживает до 3-х предыдущих версий языка. Kotlin предоставляет два флага, помогающих ограничить критические изменения :

языковая версия XY

Этот флаг отменяет критические изменения в поведении предыдущей версии Kotlin. Например, если вы используете Kotlin 1.7, вы можете указать [ - language-version 1.7] и новые критические изменения больше не вступят в силу:

android {
   kotlinOptions {
       languageVersion = '1.7'
   }
}
API-версия XY

Этот флаг предотвращает использование новых API до того, как зависимый нижестоящий код будет готов к включению Kotlin 2.0.

android {
   kotlinOptions {
       apiVersion = '1.7'
   }
}

Более целенаправленный подход

Помимо использования флагов совместимости Kotlin, мы рекомендуем просмотреть примечания к выпуску Kotlin и выбрать поведение, которое вы хотели бы сохранить в версии, с которой вы обновляетесь. Kotlin предоставляет список критических изменений и флагов, которые можно установить для сохранения исходного поведения, в руководствах по совместимости для каждой версии: