diff --git a/src/corelib/Qt6AndroidMacros.cmake b/src/corelib/Qt6AndroidMacros.cmake index d54b884c573..bae9ee44cbf 100644 --- a/src/corelib/Qt6AndroidMacros.cmake +++ b/src/corelib/Qt6AndroidMacros.cmake @@ -259,6 +259,8 @@ function(qt6_android_generate_deployment_settings target) list(JOIN architecture_record_list "," architecture_records) # Architecture + string(APPEND file_contents + " \"abi\": \"${CMAKE_ANDROID_ARCH_ABI}\",\n") string(APPEND file_contents " \"architectures\": { ${architecture_records} },\n") diff --git a/src/tools/androiddeployqt/main.cpp b/src/tools/androiddeployqt/main.cpp index 0eb83cc3486..4094d86809c 100644 --- a/src/tools/androiddeployqt/main.cpp +++ b/src/tools/androiddeployqt/main.cpp @@ -143,6 +143,7 @@ struct Options QString jdkPath; // Build paths + QString abi; QString qtInstallDirectory; QHash qtDirectories; QString qtDataDirectory; @@ -1184,6 +1185,11 @@ bool readInputFile(Options *options) options->targetSdkVersion = ver.toString().toUtf8(); } + { + if (const auto abi = jsonObject.value("abi"_L1); !abi.isUndefined()) + options->abi = jsonObject.value("abi"_L1).toString(); + } + { const QJsonObject targetArchitectures = jsonObject.value("architectures"_L1).toObject(); if (targetArchitectures.isEmpty()) {