Я работаю над простым приложением с реагирующим нативным (/expo). Когда я делаю что-то простое, например следующие 4 команды (по порядку в Windows 11, Expo 51):
npx create-expo-app Test --template
(выбран шаблон Blank
; без Typescript)cd Test
npm install
npx expo run:android
Я получаю следующий вывод и ошибку:
📝 Android package Learn more: https://expo.fyi/android-package
√ What would you like your Android package name to be? ... com.pmaddineedi.Test
√ Created native directory
√ Updated package.json
» android: userInterfaceStyle: Install expo-system-ui in your project to enable this feature.
√ Finished prebuild
› Building app...
Configuration on demand is an incubating feature.
FAILURE: Build failed with an exception.
* What went wrong:
Could not open settings generic class cache for settings file 'C:\Users\pmadd\Mobile Development\Audacity\Test\android\settings.gradle' (C:\Users\pmadd\.gradle\caches\8.6\scripts\9jvl7af6mie02hkplgyjc1nfd).
> BUG! exception in phase 'semantic analysis' in source unit '_BuildScript_' Unsupported class file major version 66
* Try:
> Run with --stacktrace option to get the stack trace.
> Run with --info or --debug option to get more log output.
> Run with --scan to get full insights.
> Get more help at https://help.gradle.org.
BUILD FAILED in 758ms
Error: C:\Users\pmadd\Mobile Development\Audacity\Test\android\gradlew.bat app:assembleDebug -x lint -x test --configure-on-demand --build-cache -PreactNativeDevServerPort=8081 -PreactNativeArchitectures=x86_64,arm64-v8a exited with non-zero code: 1
Error: C:\Users\pmadd\Mobile Development\Audacity\Test\android\gradlew.bat app:assembleDebug -x lint -x test --configure-on-demand --build-cache -PreactNativeDevServerPort=8081 -PreactNativeArchitectures=x86_64,arm64-v8a exited with non-zero code: 1
at ChildProcess.completionListener (C:\Users\pmadd\Mobile Development\Audacity\Test\node_modules\@expo\spawn-async\build\spawnAsync.js:42:23)
at Object.onceWrapper (node:events:634:26)
at ChildProcess.emit (node:events:519:28)
at cp.emit (C:\Users\pmadd\Mobile Development\Audacity\Test\node_modules\cross-spawn\lib\enoent.js:34:29)
at maybeClose (node:internal/child_process:1105:16)
at ChildProcess._handle.onexit (node:internal/child_process:305:5)
...
at spawnAsync (C:\Users\pmadd\Mobile Development\Audacity\Test\node_modules\@expo\spawn-async\build\spawnAsync.js:7:23)
at spawnGradleAsync (C:\Users\pmadd\Mobile Development\Audacity\Test\node_modules\@expo\cli\build\src\start\platforms\android\gradle.js:96:48)
at assembleAsync (C:\Users\pmadd\Mobile Development\Audacity\Test\node_modules\@expo\cli\build\src\start\platforms\android\gradle.js:74:18)
at runAndroidAsync (C:\Users\pmadd\Mobile Development\Audacity\Test\node_modules\@expo\cli\build\src\run\android\runAndroidAsync.js:45:37)
Однако npm start
работает отлично.
Как это исправить?
Обратите внимание, что я видел в Интернете множество решений этой проблемы, но ни одно из них не работает.
Я использую Java JDK 20, так как мне кажется, что мне нужна версия 17+, а версия 22 слишком новая.
Использование gradle init
со следующим вводом сработало:
Тип проекта: Приложение (2)
Язык реализации: Котлин (4)
Создать несколько подпроектов для приложения: нет
Сборка сценария DSL: Котлин (1)
Целевая версия Java: 20
Генерация сборки с использованием новых API и поведения: да