summaryrefslogtreecommitdiffstats
path: root/src/corelib/Qt6CoreMacros.cmake
diff options
context:
space:
mode:
authorAlexey Edelev <alexey.edelev@qt.io>2020-11-10 15:18:49 +0100
committerAlexey Edelev <alexey.edelev@qt.io>2020-11-12 22:11:37 +0100
commit558f5a2d7ba99d1c00132a6664f428837715e649 (patch)
treea6119b74aa164943c48a89200f5c0b29f7c5eb0b /src/corelib/Qt6CoreMacros.cmake
parent29b17fa335388c9b93f70c29b2398cf2fee65785 (diff)
CMake: Add support for -binary option for generated resources
Add handling of -binary flag in qt6_add_resources for generated resource file variant. If -binary argument is provided in OPTIONS section of qt6_add_resources function, it will be passed to rcc as argument. File path to output .rcc could be additionally specified by DESTINATION argument. Extra target generated_<resource_filename> will be added to project's 'all' set. Implement tests for new functionality. Fixes: QTBUG-87644 Change-Id: Id1313da499d86f82859d1757c3cfae2d84e894d4 Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
Diffstat (limited to 'src/corelib/Qt6CoreMacros.cmake')
-rw-r--r--src/corelib/Qt6CoreMacros.cmake68
1 files changed, 48 insertions, 20 deletions
diff --git a/src/corelib/Qt6CoreMacros.cmake b/src/corelib/Qt6CoreMacros.cmake
index 926c63736d..c70fdbef32 100644
--- a/src/corelib/Qt6CoreMacros.cmake
+++ b/src/corelib/Qt6CoreMacros.cmake
@@ -1108,7 +1108,11 @@ endfunction()
#
function(_qt_internal_process_resource target resourceName)
- cmake_parse_arguments(rcc "" "PREFIX;LANG;BASE;OUTPUT_TARGETS" "FILES;OPTIONS" ${ARGN})
+ cmake_parse_arguments(rcc "" "PREFIX;LANG;BASE;OUTPUT_TARGETS;DESTINATION" "FILES;OPTIONS" ${ARGN})
+
+ if("${rcc_OPTIONS}" MATCHES "-binary")
+ set(isBinary TRUE)
+ endif()
string(REPLACE "/" "_" resourceName ${resourceName})
string(REPLACE "." "_" resourceName ${resourceName})
@@ -1162,8 +1166,8 @@ function(_qt_internal_process_resource target resourceName)
return()
endif()
list(APPEND output_targets ${output_target_quick})
- set(generatedResourceFile "${CMAKE_CURRENT_BINARY_DIR}/.rcc/generated_${newResourceName}.qrc")
- set(generatedSourceCode "${CMAKE_CURRENT_BINARY_DIR}/.rcc/qrc_${newResourceName}.cpp")
+ set(generatedBaseName "generated_${newResourceName}")
+ set(generatedResourceFile "${CMAKE_CURRENT_BINARY_DIR}/.rcc/${generatedBaseName}.qrc")
# Generate .qrc file:
@@ -1210,10 +1214,8 @@ function(_qt_internal_process_resource target resourceName)
set(qt_core_configure_file_contents "${qrcContents}")
configure_file("${template_file}" "${generatedResourceFile}")
- set_property(TARGET ${target} APPEND PROPERTY _qt_generated_qrc_files "${generatedResourceFile}")
+ set(rccArgs --name "${newResourceName}" "${generatedResourceFile}")
- set(rccArgs --name "${newResourceName}"
- --output "${generatedSourceCode}" "${generatedResourceFile}")
if(rcc_OPTIONS)
list(APPEND rccArgs ${rcc_OPTIONS})
endif()
@@ -1228,10 +1230,29 @@ function(_qt_internal_process_resource target resourceName)
list(APPEND rccArgs "--no-zstd")
endif()
+ set_property(SOURCE "${generatedResourceFile}" PROPERTY SKIP_AUTOGEN ON)
+
+ # Set output file name for rcc command
+ if(isBinary)
+ set(generatedOutfile "${CMAKE_CURRENT_BINARY_DIR}/${generatedBaseName}.rcc")
+ if(rcc_DESTINATION)
+ # Add .rcc suffix if it's not specified by user
+ get_filename_component(destinationRccExt "${rcc_DESTINATION}" LAST_EXT)
+ if("${destinationRccExt}" STREQUAL ".rcc")
+ set(generatedOutfile "${rcc_DESTINATION}")
+ else()
+ set(generatedOutfile "${rcc_DESTINATION}.rcc")
+ endif()
+ endif()
+ else()
+ set(generatedOutfile "${CMAKE_CURRENT_BINARY_DIR}/.rcc/qrc_${newResourceName}.cpp")
+ endif()
+
+ list(PREPEND rccArgs --output "${generatedOutfile}")
+
# Process .qrc file:
- add_custom_command(OUTPUT "${generatedSourceCode}"
- COMMAND "${QT_CMAKE_EXPORT_NAMESPACE}::rcc"
- ARGS ${rccArgs}
+ add_custom_command(OUTPUT "${generatedOutfile}"
+ COMMAND "${QT_CMAKE_EXPORT_NAMESPACE}::rcc" ${rccArgs}
DEPENDS
${resource_dependencies}
${generatedResourceFile}
@@ -1239,18 +1260,25 @@ function(_qt_internal_process_resource target resourceName)
COMMENT "RCC ${newResourceName}"
VERBATIM)
- get_target_property(type "${target}" TYPE)
- # Only do this if newResourceName is the same as resourceName, since
- # the resource will be chainloaded by the qt quickcompiler
- # qml cache loader
- if(newResourceName STREQUAL resourceName)
- __qt_propagate_generated_resource(${target} ${resourceName} "${generatedSourceCode}" output_target)
- list(APPEND output_targets ${output_target})
+ if(isBinary)
+ # Add generated .rcc target to 'all' set
+ add_custom_target(binary_resource_${generatedBaseName} ALL DEPENDS "${generatedOutfile}")
else()
- target_sources(${target} PRIVATE "${generatedSourceCode}")
- endif()
- if (rcc_OUTPUT_TARGETS)
- set(${rcc_OUTPUT_TARGETS} "${output_targets}" PARENT_SCOPE)
+ set_property(SOURCE "${generatedOutfile}" PROPERTY SKIP_AUTOGEN ON)
+ set_property(TARGET ${target} APPEND PROPERTY _qt_generated_qrc_files "${generatedResourceFile}")
+
+ # Only do this if newResourceName is the same as resourceName, since
+ # the resource will be chainloaded by the qt quickcompiler
+ # qml cache loader
+ if(newResourceName STREQUAL resourceName)
+ __qt_propagate_generated_resource(${target} ${resourceName} "${generatedOutfile}" output_target)
+ list(APPEND output_targets ${output_target})
+ else()
+ target_sources(${target} PRIVATE "${generatedOutfile}")
+ endif()
+ if (rcc_OUTPUT_TARGETS)
+ set(${rcc_OUTPUT_TARGETS} "${output_targets}" PARENT_SCOPE)
+ endif()
endif()
endfunction()