summaryrefslogtreecommitdiffstats
path: root/src/android/java/CMakeLists.txt
diff options
context:
space:
mode:
Diffstat (limited to 'src/android/java/CMakeLists.txt')
-rw-r--r--src/android/java/CMakeLists.txt66
1 files changed, 58 insertions, 8 deletions
diff --git a/src/android/java/CMakeLists.txt b/src/android/java/CMakeLists.txt
index c401a36413..2ff2fb5791 100644
--- a/src/android/java/CMakeLists.txt
+++ b/src/android/java/CMakeLists.txt
@@ -1,16 +1,66 @@
-# Copyright (C) 2022 The Qt Company Ltd.
-# SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
+# Copyright (C) 2023 The Qt Company Ltd.
+# SPDX-License-Identifier: BSD-3-Clause
# Android Java Resource files
-# special case skip regeneration
-# special case begin
set(resource_directories
- res
- src)
+ "${CMAKE_CURRENT_SOURCE_DIR}/res"
+ "${CMAKE_CURRENT_SOURCE_DIR}/src"
+)
+
+set(java_bindings
+ "${CMAKE_CURRENT_SOURCE_DIR}/src/org/qtproject/qt/android/bindings/QtActivity.java"
+ "${CMAKE_CURRENT_SOURCE_DIR}/src/org/qtproject/qt/android/bindings/QtService.java"
+ "${CMAKE_CURRENT_SOURCE_DIR}/src/org/qtproject/qt/android/bindings/QtApplication.java"
+)
+
+set(strings_resouces
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-de/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-el/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-es/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-et/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-fa/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-fr/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-in/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-it/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-ja/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-ms/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-nb/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-nl/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-pl/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-pt-rBR/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-ro/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-ru/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-se/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-zh-rCN/strings.xml"
+ "${CMAKE_CURRENT_SOURCE_DIR}/res/values-zh-rTW/strings.xml"
+)
+
+add_custom_target(Qt${QtBase_VERSION_MAJOR}AndroidBindings
+ SOURCES
+ ${java_bindings}
+ ${strings_resouces}
+)
+
+qt_path_join(destination ${QT_INSTALL_DIR} ${INSTALL_DATADIR} "src/android/java")
-qt_path_join(destination ${QT_INSTALL_DIR} "src/android/java")
qt_copy_or_install(DIRECTORY ${resource_directories}
DESTINATION "${destination}"
)
-# special case end
+
+if(NOT QT_WILL_INSTALL)
+ qt_internal_copy_at_build_time(TARGET Qt${QtBase_VERSION_MAJOR}AndroidBindings
+ DIRECTORIES ${resource_directories}
+ DESTINATION ${destination})
+endif()
+
+# To avoid Java build errors after the loader classes have been moved to the internal Jar package,
+# make this step to remove them from the build folder. This mainly useful for existing builds,
+# as clean builds wouldn't have to deal with this case.
+if ("${PROJECT_VERSION}" GREATER_EQUAL "6.7")
+ set(loader_bindings "QtLoader.java" "QtActivityLoader.java" "QtServiceLoader.java")
+ foreach(binding IN LISTS loader_bindings)
+ file(REMOVE "${destination}/src/org/qtproject/qt/android/bindings/${binding}")
+ endforeach()
+endif()