Android AGP 8.4 и внедрение рукоятки в сервисAndroid

Форум для тех, кто программирует под Android
Ответить
Anonymous
 Android AGP 8.4 и внедрение рукоятки в сервис

Сообщение Anonymous »

После обновления до Android Studio Jellyfish и обновления плагина Android Gradle 8.4.0 в многомодульном проекте я больше не могу внедрить в свою службу, когда включена минимизация.
После обновлений я потратил немало времени на добавление новых правил в модули, не относящиеся к приложениям (это модули aar). Теперь приложение работает, и большинство функций снова работают. Но я не могу заставить сервис работать. В него добавлено довольно много вещей. Поскольку он работал с предыдущей версией AGP и работает с отладочной сборкой, я предполагаю, что это связано с отсутствием какого-то правила, необходимого для новой версии AGP. Он действительно действует, не видит аннотаций. В этом модуле у меня те же правила хранения аннотаций, что и в других модулях, и они получают свои инъекции.
Я сократил сервис до:@AndroidEntryPoint
open class MyService : Service() {
@Inject
lateinit var test: DTest

override fun onCreate() {
super.onCreate()

Timber.d("onCreate, ${test.test}")
}

override fun onBind(intent: Intent?): IBinder? {
return null
}
}

Где DTest находится в том же модуле и просто:
@InstallIn(SingletonComponent::class)
@Module
object TestModule {
@Provides
@Singleton
fun providesDTestModule(): DTest {
return DTest("TestModule")
}
}

data class DTest(val test: String)

При запуске службы получается такой результат:
E java.lang.RuntimeException: Unable to create service my.package.MyService: kotlin.UninitializedPropertyAccessException: lateinit property test has not been initialized
E at android.app.ActivityThread.handleCreateService(ActivityThread.java:4664)
E at android.app.ActivityThread.-$$Nest$mhandleCreateService(Unknown Source:0)
E at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2264)
E at android.os.Handler.dispatchMessage(Handler.java:106)
E at android.os.Looper.loopOnce(Looper.java:205)
E at android.os.Looper.loop(Looper.java:294)
E at android.app.ActivityThread.main(ActivityThread.java:8177)
E at java.lang.reflect.Method.invoke(Native Method)
E at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:552)
E at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:971)
E Caused by: kotlin.UninitializedPropertyAccessException: lateinit property test has not been initialized
E at my.package.MyService.onCreate(SourceFile:8)
E at android.app.ActivityThread.handleCreateService(ActivityThread.java:4651)
E ... 9 more


Подробнее здесь: https://stackoverflow.com/questions/784 ... -a-service
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»